我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Oracle高级查询

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Oracle高级查询

本章将学习的内容有:

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

  • 使用TRANSLATE函数

1、使用集合操作符

    

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

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

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

    Oracle高级查询

    Oracle高级查询

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

2、使用TRANSLATE函数

    TRANSLATE(x,from_string,to_string)函数在x中查找from_string中的字符,并将其转换成to_string中对应的字符。Oracle高级查询

3、使用DECODE()函数

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

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

    Oracle高级查询

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;



免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Oracle高级查询

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mongodb高级聚合查询

https://www.cnblogs.com/zhoujie/p/mongo1.htmlmongodb高级聚合查询   在工作中会经常遇到一些mongodb的聚合操作,特此总结下。mongo存储的可以是复杂类型,比如数组、对象等mysql不善于处理的文档型结
mongodb高级聚合查询
2016-06-26

【MySQL】细谈SQL高级查询

文章目录 一、前言 & 准备工作二、简易高级查询⚙ 准备工作1、查询每一门课程及其先修课程2、查询和“刘涛”在一个班级的学生的信息3、查询选修了‘计算机基础’课的学生的学号、姓名③ 连接方式④ 子查询嵌套方式 4、查询没有
【MySQL】细谈SQL高级查询
2023-12-23

软考高级成绩在哪里查询?软考高级成绩查询入口

软考高级成绩在哪里查询?软考高级成绩查询入口是哪个?软考高级成绩在中国计算机技术职业资格网查询,网站网址https://www.ruankao.org.cn/。软考高级成绩查询入口流程有三种方式,详见正文。

软考高级成绩查询入口2024上半年软考高级成绩查询

软考高级成绩查询入口是哪个?2024上半年软考高级成绩怎么查询?这是考生目前关心的问题,为此小编为大家带来2024上半年软考高级成绩查询相关的资讯内容。
软考高级成绩查询入口2024上半年软考高级成绩查询
2024-06-05

MySQL高级(五)——慢查询日志

具体指运行时间超过long_query_time值的SQL,则会被记录到慢查询日志中。long_query_time的默认值为10,意思是运行10秒以上的语句。由他来查看哪些SQL超出了我们的最大忍耐时间值,比如一条sql执行超过5秒钟,我们就算慢SQL,希望
MySQL高级(五)——慢查询日志
2018-03-26

软考高级成绩多久可查询?软考高级成绩查询时间及入口

  软考高级成绩多久可查询?软考高级成绩在哪里查询?软考高级成绩查询入口网站为中国计算机技术职业资格网,从软考高级历年成绩查询时间来看,考试成绩一般在考后2个月内公布。  软考高级成绩查询时间在考后40天左右,成绩查询入口网站为中国计算机技术职业资格网,网站网址:https://www.ruankao.org.cn/。
软考高级成绩多久可查询?软考高级成绩查询时间及入口
2024-04-19

软考高级成绩查询入口官网2024下半年软考高级成绩查询

软考高级成绩查询入口官网为中国计算机技术职业资格网,2024下半年软考高级成绩查询时间为12月初。待2024下半年软考高级考试成绩公布,考生即可登录中国计算机技术职业资格网查询。若考生对考试成绩有异议,可在规定时间内申请成绩复查。
软考高级成绩查询入口官网2024下半年软考高级成绩查询
2024-10-28

MySQL高级查询语法是什么

这篇文章将为大家详细讲解有关MySQL高级查询语法是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、排序排序查询语法:select * from 表名 order by 列1 asc/desc [,
2023-06-29

编程热搜

目录