文档章节

Oracle高级查询

kukudeku
 kukudeku
发布于 2016/06/18 09:19
字数 1599
阅读 22
收藏 0
点赞 0
评论 0

本章将学习的内容有:

  • 如何使用集合操作符,集合操作符用于将两个或多个查询返回的行组合起来

  • 使用TRANSLATE函数

1、使用集合操作符

    

操作符
说明
UNION ALL
返回各个查询检索出的所有行,包括重复行
UNION
返回各个查询检索出的所有行,不包括重复行
INTERSECT
返回两个检索锁的共有行
MINUS
返回将第二个查询检索出的行从第一个查询检索的行中去除之后的行

    注意:当使用集合操作符的时候,必须牢记这样一条限制:所有查询返回的列数以及列的类型必须匹配,但列名可以不同。

    使用INTERSECT查找两次检索结果中有相同的结果

    wKioL1dhQISDcgorAAAk8vgPR8c926.png-wh_50

    wKiom1dhP_6wE3CjAAAmPWzjel8543.png-wh_50

    使用MINUS操作返回第一个结果去除第二个查询结果之后的结果。(有兴趣的童鞋可以自行测试下)

2、使用TRANSLATE函数

    TRANSLATE(x,from_string,to_string)函数在x中查找from_string中的字符,并将其转换成to_string中对应的字符。wKioL1dhRBnh1paKAABQBHFdto4629.png-wh_50

3、使用DECODE()函数

    DECODE(value,search_value,result,default_value) 对value与search_value进行比较。如果这两个值相等,DECODE()返回result,否则返回default_value。

DECODE()允许在SQL中执行if-then-else类型的逻辑处理。

    wKioL1dhRTaD-rGEAAAp25Yq-RU675.png-wh_50

4、使用CASE表达式

    case表达式可以在SQL中实现if-then-else型逻辑,case表达式的工作方式与decode()类似,但是我们应该使用case,因为它兼容ANSI,并且已经成为SQL/92标准的一部分另外case表达式易读。语法:

case search_expression

when expression1 then result1

when expression2 then result2

...

when expressionN then resultN

else default_result

end

5、使用分析函数

    数据库中有很多内置的分析函数,能够执行复杂的计算,例如查找每月销量最高的商品类行,业绩最佳的销售员等。分析函数可以分为以下几类。

  • 评级函数:可计算等级、百分比等

  • 反百分比函数:可计算对应于百分点的数值

  • 窗口函数:可计算累积和移动总计

  • 报表函数:可计算注入市场占有率之类的结果

  • 延迟与领先函数:可获得与当前记录的记录为若干条记录的那个记录的值

  • 首函数与末函数:可获得某个已经排序的第一个和最后一个返回值

  • 线性回归函数:可用一条普通最小平方回归曲线来拟合一组数值对

5、修改表内容

使用INSERT语句添加行

当省略列的列表时,指定的顺序必须与DESCRIBE命令输出结果显示的列的顺序一致

要为控制指定NULL值

从一个表向另一个表复制行。要求:源表和目标表的列数以及列的类型必须匹配

SQL>INSERT INTO cboss.fault_barrier_base_code(code_type,code_id)
    SELECT c.code_type,c.code_id
    FROM cboss.cboss_base_code
    WHERE c.serialno < 100

使用UPDATE语句修改行

使用RETURNING子句,返回使用聚合函数如AVG()计算的结果。

使用DELETE语句删除行

6、数据库的完整性

6.1、主键约束。主键的每一个值必须是唯一的primary key

6.2、外键约束。foreign key。。 references

6.3、使用默认值default

6.4、使用MERGE合并行

6.5、数据库事务(transaction)是一组SQL语句,这组SQL语句就是一个逻辑工作单元。事务是不可分割的SQL语句,其结果应该作为一个整体永久性地修改数据库的内容

或者取消对数据库的修改

6.5.1、事务的提交和回滚

    事务提交需要执行COMMIT语句,从而提交(commit)事务。要取消SQL语句的结果,需要执行ROLLBACK语句,从而回滚(rollback)事务,将所有行重新设置为原始状态。

6.52、事务的开始与结束

    事务是用来分割SQL语句的逻辑工作单元。事务既有起点也有终点。执行DML语句的时候事务开始。执行COMMIT或者ROLLBACK时事务结束。执行DDL语句,如CREATE自动提交事务。执行DCL语句,例如GRANT语句,自动提交事务。

6.5.3、设置保存点,SAVEPOINT,可以将修改回滚到保存点。这对一个大事务来说很有用。

6.5.4、事务的ACID特性

    原子性(Atomic)事务是原子的,不可分割

    一致性(Consist)事务必须确保数据库的状态保持一致,事务结束,数据库状态时结束,事务开始,数据库状态也是开始

    隔离性(Isolated)多个事务之间是独立运行的,互不影响

    持久性(Durale)一旦事务被提交,数据的变化就会被永远的保留下来。

6.5.5、并发事务

    Oracle数据库软件支持多个用户同时与数据库进行交互,每个用户都可以同时运行自己的事务。这种事务成为并发事务(concurrent transaction)。

    要支持并发事务,Oracle数据库软件必须保证表中的数据一直有效,这可以通过锁(Lock)来实现。

7、用户、特权和角色

创建用户:

CREATE USER user_name IDENTIFIED BY password
[DEFAULT TABLESPACE default_tablespace]
[TEMPORARY TABLESPACE temporary_tablespace]

给用户授权:

GRANT PRIVILIGE TO USER;
示例:
GRANT CREATE,DROP,CONNECT TO USER_NAME;
查看用户系统特权
SELECT * FROM USER_SYS_PRIVS ORDER BY PRIVILEGE;
查看用户对象特权
SELECT * FROM USER_TAB_PRIVS;
撤销用户特权
REMOVE PRIVELES FROM USER_NAME
示例
REMOVE CREATE,CONNECT FRMO USER_NAME;

角色(role)就是一组特权,他可以分配给一个用户或者其他角色

角色的优点和特性:

  • 并不是一次一个地将特权直接授予一个用户,而是先创建角色,向该角色授予一些特权,然后再将角色授予多个用户和角色

  • 在增加和删除一个角色的某种特权时,被授予该角色的所有用户和角色都会自动获得新加的特权或者自动失去这种特权

  • 可以将多个角色授予一个用户或角色

  • 可以为角色设置密码

创建角色
CREATE ROLE user_manager;
设置密码
CREATE ROLE admin_manager IDENTIFIED BY admin_password;
#为角色授权
GRANT PRIVILEGES ON TABLE_NAME TO USER_MANAGER;
#将角色授予用户
GRANT ROLE_NAME TO USER_NAME;



本文出自 “阿酷博客源” 博客,请务必保留此出处http://aku28907.blog.51cto.com/5668513/1789687

© 著作权归作者所有

共有 人打赏支持
kukudeku
粉丝 120
博文 41
码字总数 107831
作品 0
杭州
程序员
Oracle性能优化之物化视图管理_超越OCP精通Oracle视频教程培训39

Oracle性能优化之物化视图管理超越OCP精通Oracle视频教程培训39 课程介绍 风哥Oracle视频教程<>的第9/10套:Oracle性能优化之物化视图管理。物化视图(materialized view)基础概述,物化视图...

风哥Oracle ⋅ 2017/03/21 ⋅ 0

Win10 64位系统中PLSQL显示乱码-无法进行中文条件查询解决

原因:PLSQL乱码问题皆是ORACLE服务端字符集编码与PLSQL端字符集编码不一致引起。类似乱码问题都可以从编码是否一致上面去考虑。 解决: 查询Oracle服务端字符集编码,获取NLS_CHARACTERSET字...

铂金小猴 ⋅ 2016/10/15 ⋅ 0

Eova 1.5.1 Oracle 兼容,Java Web 快速开发平台

主要兼容Oracle,Mysql用户自行判定是否有更新必要! 兼容Oracle,提供Oracle完整脚本、配置,可直接运行! [新增]可在界面直接配置多子表 [新增]排除不需要登录拦截的URL // 不需要登录拦截...

Jieven ⋅ 2016/02/16 ⋅ 14

Oracle数据库学习的福利来啦——最佳入门经验分享

适用人群:从事数据库技术实施或售后工程师,准备参加OCA,OCP认证考试 通过学习对Oracle数据库的相关基础知识进行梳理,最终共同提炼出必须最先掌握的那部分知识,无论你是数据库开发、管理、...

让往事随风 ⋅ 2016/04/13 ⋅ 0

Oracle 的 Node.js 驱动--node-oracledb

node-oracledb 是甲骨文公司官方发布的 Oracle 的 Node.js 驱动。目前最新版本 0.2 还是个预览版本,开发团队还在不断完善,包括对 Windows 平台的支持、LOB 支持、批获取/大查询结果集的流处...

红薯 ⋅ 2015/01/28 ⋅ 7

PostgreSQL Oracle 兼容性 - Analysis函数之keep

标签 PostgreSQL , Oracle , 分析函数 , 窗口函数 , keep 背景 Oracle 分析函数KEEP,类似OVER的语法结构(当然,含义与之不同)。keep可以用于普通的查询,也可以用于分组聚合,同时亦可用于...

德哥 ⋅ 06/21 ⋅ 0

Oracle TopLink

Oracle TopLink Essentials是由Oracle公司推出,EJB3.0规范(JSR 220)中的JPA部分的标准实现。Java开发者可以利用TopLink所提供的强大功能,快速开发具有高性能的企业应用程序。 Oracle Top...

匿名 ⋅ 2008/09/16 ⋅ 0

Oracle11gR2 数据库客户端PL/SQL中文乱码的问题

在进行oracle数据库的数据操作时,发现中文出现了乱码。这真是件麻烦事情。其实解决乱码的问题很简单,需要我们的PL/SQL Oracle客户端的字符集编码和Oracle数据库的字符集编码保持一致。 1、...

pmos ⋅ 2016/09/07 ⋅ 0

复习Oracle中的一点知识

Oracle 10g Oracle是为网格计算而设计的 10g中的g就是指grid computing Oracle将数据存储在文件中,保存不同信息的文件(数据文件,控制文件,日志文件)就组成了数据库的物理结构 逻辑结构:...

Mybbz ⋅ 2014/08/19 ⋅ 0

本地不安装Oracle,plsql远程连接数据库

由于Oracle的庞大,有时候我们需要在只安装Oracle客户端如plsql、toad等的情况下去连接远程数据库,可是没有安装Oracle就没有一切的配置文件去支持。最后终于发现一个很有效的方法,Oracle的...

Zero零_度 ⋅ 2016/06/03 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

如何使用serverchan微信推送告警

之前实现推送告警信息到微信的方法有如下几种: 1、通过企业公众号实现----收费: 2、通过QQ邮箱,在微信平台上开启收到邮件进行提醒; 3、第三方告警平台API,一般也是收费的; 不过最近看文...

问题终结者 ⋅ 13分钟前 ⋅ 0

TCP的RPC

RPC就是远程方法调用(Remote Process Call ),包含了客户端和服务端,涉及了对象的序列化传输。 1.服务端启动,注册远程调用的类2.客户端发送请求信息包含类、方法、参数的一些信息、序列化传...

Cobbage ⋅ 34分钟前 ⋅ 0

IOS-UI UI初步代码布局添加事件

ISO开发界面,UI是必须学习的一部分,其实很早之前想学来了,一直没有沉下心来学习。看到IOS的代码风格和布局就别扭的不行,跟java代码和android布局比较显得不是那么方便,所以一直到现在。...

京一 ⋅ 44分钟前 ⋅ 0

浅谈OpenDaylight的二次开发

OpenDaylight作为一款开源SDN网络控制器,依托于强大的社区支持以及功能特性,成为了目前主流的SDN网络控制器开发平台。在比较稳定的OpenDaylight Helium版本中,已经为开发者提供了大量的网...

wangxuwei ⋅ 53分钟前 ⋅ 0

API 开发中可选择传递 token 接口遇到的一个坑

在做 API 开发时,不可避免会涉及到登录验证,我使用的是jwt-auth 在登录中会经常遇到一个token过期的问题,在config/jwt.php默认设置中,这个过期时间是一个小时,不过为了安全也可以设置更...

等月人 ⋅ 54分钟前 ⋅ 0

Java NIO之文件处理

程序要操作本地操作系统的一个文件,可以分为以下三个部分: 对文件位置的操作 对文件的操作 对文件内容的操作 其中,对文件内容的操作在 Java NIO之Channel 中已经有了介绍,通过FileChann...

士别三日 ⋅ 59分钟前 ⋅ 0

Maven的pom.xml配置文件详解

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.......

小海bug ⋅ 今天 ⋅ 0

解决httpclient超时设置不生效的问题

最近公司有项目需要通过http调用第三方服务,且第三方服务偶有超时,故需要设置一定的超时时间防止不响应的情况出现。 初始设置如下: [java] view plain copy //超时设置 RequestConfig re...

Mr_Tea伯奕 ⋅ 今天 ⋅ 0

过滤器Filter和拦截器HandlerInterceptor

过滤器 依赖于servlet容器。在实现上基于函数回调,可以对几乎所有请求进行过滤,但是缺点是一个过滤器实例只能在容器初始化时调用一次。使用过滤器的目的是用来做一些过滤操作,获取我们想要...

hutaishi ⋅ 今天 ⋅ 0

Redis入门详解(转)

Redis入门详解 Redis简介 Redis安装 Redis配置 Redis数据类型 Redis功能 持久化 主从复制 事务支持 发布订阅 管道 虚拟内存 Redis性能 Redis部署 Redis应用场景 Redis总结 Redis简介: Redi...

xiaoyaoyoufang ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部