SQL> insert into test select * from test; 最后,查询该表,可以看到该表的记录数约为 80 万条。...10246 consistent gets 0 physical reads 0 redo size …… 可以看到,这种方式查询第一页的一致性读有...从以上的例子可以看到,通过把 rownum 引入到第 二层,却得到了一个完全不一样的执行计划,注意在执行计划中的 stopkey,它是 8i 引入的新操 作,这种操作专门为提取 Top n 的需求做了优化
原则二:SELECT子句中避免使用 ‘ * ‘: ORACLE在解析的过程中, 会将'*' 依次转换成所有的列名, 这个工作是通过查询数据字典完成的, 这意味着将耗费更多的时间 。...优势: 1)索引是表的一个概念部 分,用来提高检索数据的效率,ORACLE使用了一个复杂的自平衡B-tree结构. 通常,通过索引查询数据比全表扫描要快....当ORACLE找出执行查询和Update语句的最佳路径时, ORACLE优化器将使用索引....当ORACLE”遇到”NOT,他就会停止使用索引转而执行全表扫描. 2、避免在索引列上使用计算. WHERE子句中,如果索引列是函数的一部分.优化器将不使用索引而使用全表扫描....因为子查询的开销是相当昂贵的。具体的例子在后面的案例“一条SQL的优化过程”中。
概述 1 查询表中所有的行与列 2 从表中检索部分行 3 查找空值 4 将空值转换为实际值 5 查找满足多个条件的行 6 从表中检索部分列 7 为列取有意义的名称 8 在 WHERE 子句中引用取别名的列...9 拼接列 使用字符串连接符 用SQL生成SQL 10 在 SELECT 语句中使用条件逻辑 case when 11 限制返回的行数 12 从表中随机返回 n 条记录 13 模糊查询 查出vname...NVL(NVL(NVL(C1,C2),C3) ---------------------------------------- 1 3 SQL> ---- 1.5 查找满足多个条件的行 对于简单的查询...比如 ,查询部门号10中的所有员工、所有得到提成的员工、以及部门20中工资不超过2000的员工。 这是三个条件的组合,符合上述任一一条即可。...select ename, job, sal, comm from emp order by dbms_random.value()) where rownum <= 3; ---- 1.13 模糊查询
1以指定的次序返回查询结果 问题 解决方案 总结 2按多个字段排序 问题 解决方案 总结 3按子串排序 问题 解决方案 总结 4 TRANSLATE 语法 工具 总结 5 按数字和字母混合字符串中的字母排序...问题 解决方案 总结 6 处理排序空值 - nulls first 和 nulls last 问题 解决方案 总结 7 根据条件取不同列中的值来排序 问题 解决方案 总结 2.1以指定的次序返回查询结果...如果在查询中使用group by 或者distinct,则不能按照select列中 ---- 2.3按子串排序 问题 按照字符串的某一部分对查询结果进行排序。...Oracle 将空字符串解释为 NULL,并且如果TRANSLATE 中的任何参数为NULL,那么结果也是 NULL。...解决方案 oracle9i以后 可以使用关键字 nulls first 和 nulls last 来确保null是首先排序还是最后排序,而不必考虑非空值的排序方式。
.* from user_ind_columns a 5.4 列出表约束 查询 sys.all_constraints 和 sys.all_cons_columns select a.TABLE_NAME...SQL 举例:生成SQL来统计所有表中的行数 select 'select count(1) from ' || table_name || ';' from user_tables ; 5.7 在oracle...中描述数据字典视图 列出数据字典视图和他们的用途 select * from dictionary a order by a.TABLE_NAME ; 查询数据字典中的列 select *
使用Oracle sqlplus 进行查询时经常会碰到查询结果显示问题,字段和查询结果难以直接对应显示。...这个是因为 sqlplus 的设置问题,在 Windows 环境下,可直接在查询窗口“右键-环境”,修改屏幕显示的缓冲区设置,将设置值调整到合适的值,确定即可。...Linux 环境下可直接设置环境变量 set pagesize xxx; set linesize xxx; 修改显示的方式有很多,但都是通过修改相应的环境变量值来达到显示优化效果。
导语 本文分析基于11.2.0.4版本,通过整个问题的分析和解决过程,希望能够大家对大结果集下标量子查询的存在的性能问题以及为如何、为什么改写有所帮助,而不是说标量子查询一定不好,有时候可能需要改写为标量子查询...,小结果集标量子查询FILTER执行计划优先NL(外层表存在重复多的情况)....背景 群中小伙伴遇到生产环境SQL执行1小时都没有出来,是一个insert select,如下是查询语句部分,从语句写法来看应该是N:N关系,这个是标量子查询语句.类似NL,不能使用HASH...需要了解标量子查询特征: 1、外层表传值到内层表,找到结果,则为NULL 2、如果匹配到则返回最多有且只有1行1列值,返回多行则会报错。...备注:2个表满足:N:1,1:1,1:N,N:N关系 2、验证结果集--2者结果集相同,说明改写是正确的. 1、原始SQL结果集 2、LEFT JOIN结果集 总结 通过了解标量子查询固有特征
——多表查询的技巧与优化方式,下面依旧通过一次例子看一个最简单的多表查询。...还有一点需要明确,在早期的版本中仿佛有这样的规则: 子查询结果集小,用IN。 外表小,子查询表大,用EXISTS。 这两个说法在Oracle11g中已经是完全错误的了!...在Oracle8i中这样也许还经常是正确的,但Oracle 9i CBO就已经优化了IN和EXISTS的区别,Oracle优化器有个查询转换器,很多SQL虽然写法不同,但是Oracle优化器会根据既定规则进行查询重写...,重写为优化器觉得效率最高的SQL,所以可能SQL写法不同,但是执行计划却是完全一样的,所以还有个结论就是:关于IN和EXISTS哪种更高效应该及时查看PLAN,而不是记固定的结论,至少在目前的Oracle...总结 简单记录一下Oracle多表查询中的各种模式以及个人认为值得注意的一些点和优化方式,希望对读到的同学有所帮助和提高,The End。
编辑手记:前面我们介绍常用的子查询优化方法,但总有一些情况时在规律之外。谨慎处理方能不掉坑。...前文回顾: 性能优化之查询转换 - 子查询类 将SQL优化做到极致 - 子查询优化 作者简介: 韩锋 ?...精通包括Oracle、MySQL、informix等多种关系型数据库,有丰富的数据库架构设计开发经验。就职于宜信。...第二个值得关注的是,在11g之前,如果主表和子表的对应列未同时有NOT NULL约束,或都未加IS NOT NULL限制,则Oracle会走FILTER。...在确定子查询列object_id不会有NULL存在的情况下,又不想通过增加NOT NULL约束来优化,可以通过上面方式进行改写 ?
7.1 加减日、月、年 在oracle中,date类型可以直接加减天数,而加减月份要用add_months函数. select a.hiredate 雇用日期, a.hiredate +
在处理大结果集时要记住,使用UNION子句大致相当于下面的查询,对UNION ALL子句的查询结果使用DISTINCT子句 SQL> select distinct deptno 2 from...解决方案 ORACLE VERSION : Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 IN SQL> explain plan...解决方案 自关联,也就是两次查询表emp,分别取不同的别名,这样就可以当做是两个 表,后面的任务就是将这两个表 join连接起来即可。...主管.empno) order by 1; ---- 3.7 NOT IN、NOT EXISTS 和 LEFT JOIN 问题 有些单位的部门如40中一个员工也没有,只是设置了一个部门名字,如何通过关联查询把这些信息查询出来呢...这是很多人写查询或者改查询时常遇到的一种错误, 问题在于所加条件的位置及写法。 那该如何做呢?
大家好,我是 JiekeXu,很高兴又和大家见面了,今天和大家一起来看一下 Oracle 单表分页查询优化 近日中午一开发过来说生产有条 SQL 执行缓慢,让看一下执行计划。...ORACLE 10g 以后提供了一个脚本 sqltrpt.sql 用来查询最耗费资源的 SQL 语句,也可以根据输入的 SQL_ID,生成对应执行计划和调优建议, 是一个不错的调优优化脚本,其实是 sqltrpt...、ash 报告,监控工具等获取到,v$sql 如上查询会出现很多个SQL。...那么该 SQL 还有优化的空间吗? 11、根据《SQL优化核心思想》8.3 一节 分页优化思想改写的 SQL 如下: select * from (select * from (select a....看过老虎刘老师的最高效分页查询语句架构只有三层,我们来套用看看。
1 查询语句 查看账户下的所有表 1 select * from tab; 查看账户下的所有表的详细信息 1 select * from user_tables; 1.1 select select 用于从数据看查询数据...语法: 1 select field1,filed2,.. . 2 from tablename 3 [where condition]; 利用 Oracle 数据库 Scott 账户下的 EMP 表进行练习...1.3 where 字句 where 表示查询的条件。 =,!...当需要查询的格式包含关键字,需要用转义字符。...1 -- nvl函数优化 2 select e.ename,e.sal+nvl(e.comm,0) "收入",e.deptno 3 from emp e;
作为一种简便方式,在insert语句中,可以省略字段列表, 然而,如果语句中没有列出要插入行中的目标字段,则必须要插入表中的所有列,需要注意的,在插入值列表中所列出的值的顺序,必须与select * 查询语句所列出的列顺序完全一致...test_xgj ; SQL> insert into test_xgj_view(c1,c2,c3) values ('默认值2',NULL ,'C3'); SQL> commit ; --查询下...---- 4.5多表插入语句 oracle从9i开始可以用一条insert语句实现向多个表中插入数据 Oracle Insert all有三种情况: 一、无条件 INSERT ALL 二、条件...语法: INSERT [ALL] [conditional_insert_clause] [insert_into_clause values_clause](subquery) subquery:子查询语句..., Oracle 服务器执行每一个 insert_into_clause一次。
题记:SQL优化及SQL审核,是从源头解决性能问题的根本手段,无论是开发人员还是DBA,都应当持续深入的学习SQL开发技能,从而为解决性能问题打下根基。...本系列经典文章 之一:标量子查询优化 之二:OR展开与子查询优化案例详解。 今天是系列第三讲:IN子查询返回结果集异常 作者简介: ?...这里看到,存在两个子游标,他们的执行计划相等,但是两个子优化的性能相差很大,并且性能不好的子优化执行次数很多。 在上面我们提到主查询就只存在两个过滤条件。...下面就是怎么来优化这个SQL。在上面提到了子查询中最多返回10行,可以用于做NL的驱动,要让子查询的表做驱动表,应该怎么来修改SQL?...优化SQL后,CPU使用率从原来的70%左右直接下降到25%左右,此系统的主机性能很NB的,8路的PC ,E7的CPU。
java实现mysql分页查询 1.前言 1.mysql中分页用limit,但是limit后面不能跟表达式 ,错误表达式:limit (1-1)*10,10。 2.对象中提供分页数据的方法。.../ private int pageNo = 0; /** * 每页显示的条数 */ private int pageSize = 10; /** * 当前页,需要查询的页数...* pageNo从1开始 */ private int startNum; /** * 设置分页查询数据 */ public void setPageQuery() {...Mybatis–Mapping.xml mapping.xml中的分页查询sql: 主要看这段,pageNo>0表示是分页查询,不是全量查询。...分页对象写成以下两种,并在调用处去掉model.setPageQuery(); /** * 当前页,需要查询的页数 * pageNo从1开始 */ private int startNum
本文使用到的是oracle数据库scott方案所带的表,scott是oracle数据库自带的方案,使用前请确保其解锁 Oracle分页一共有三种 1、使用rownum配合子查询进行分页 rownum是一种伪列...利用rownum,关于rownum的具体细节,参考Oracle rownum我们可以生产一些原先难以实现的结果输出。...的范围来读取我们需要的记录集 select rownum,a.* from (select * from emp) a where rownum=6 执行sql,发现没有结果集产生,原因是:oracle...规定rownum作为判断条件只能在一条查询语句中出现一次,如果当前使用rownum的查询是子查询,外部查询还需要使用到rownum,那么外部查询就需要使用子查询中rownum的别名,正确的简单分页如下:...并将上面的查询和游标相结合,提高查询的效率。
start with connect by prior 递归查询用法 这个子句主要是用于B树结构类型的数据递归查询,给出B树结构类型中的任意一个结点,遍历其最终父结点或者子结点。...以7为例,看一下代码 今天面试遇到了问Oracle有自己的递归查询,依次总结下。 今天文章到此就结束了,感谢您的阅读,Java架构师必看祝您升职加薪,年年好运。
速查: start with找到第一个节点 拿到新节点,prior的值更新为新节点的值,继续按条件查询 goto 2 0 测试数据 create table tb_menu( id number(10...如果没有prior关键字,只能查询出21和22节点: 1 / | \ 6 7 8 / \ ... 21 22 查询出21和22节点 | | 38 39 那么想继续递归查询呢?...m.parent=prior m.id,关键字紧挨id,代表id可变,即拿到21和22后,对21和22继续做查询,条件变成m.parent= 21和m.parent= 22。...2 下到上递归查询 查找一个节点的所有直属父节点(祖宗) select * from tb_menu m start with m.id=38 connect by prior m.parent=m.id
start with connect by prior 递归查询用法 这个子句主要是用于B树结构类型的数据递归查询,给出B树结构类型中的任意一个结点,遍历其最终父结点或者子结点。...今天面试遇到了问Oracle有自己的递归查询,依次总结下。
领取专属 10元无门槛券
手把手带您无忧上云