首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Oracle查询性能优化

原则二:SELECT子句中避免使用 ‘ * ‘: ORACLE在解析的过程中, 会将'*' 依次转换成所有的列名, 这个工作是通过查询数据字典完成的, 这意味着将耗费更多的时间 。...而对于查询语句,由于全表扫描读取的数据多,尤其是对于大型表不仅查询速度慢,而且对磁盘IO造成大的压力,通常都要避免,而避免的方式通常是使用索引Index。 使用索引的优势与代价。...性能上将无法使用该索引.对于单列索引,如果列包含空值,索引中将不存在此记录....对于复合索引,如果每个列都为空,索引中同样不存在此记录. ...因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引.

2.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Oracle性能优化-子查询到特殊问题

    前文回顾: 性能优化之查询转换 - 子查询类 将SQL优化做到极致 - 子查询优化 作者简介: 韩锋 ?...精通包括Oracle、MySQL、informix等多种关系型数据库,有丰富的数据库架构设计开发经验。就职于宜信。...1、空值问题 首先值得关注的问题是,在NOT IN子查询中,如果子查询列有空值存在,则整个查询都不会有结果。这可能是跟主观逻辑上感觉不同,但数据库就是这样处理的。因此,在开发过程中,需要注意这一点。...第二个值得关注的是,在11g之前,如果主表和子表的对应列未同时有NOT NULL约束,或都未加IS NOT NULL限制,则Oracle会走FILTER。...如果限制性强的条件在子查询,一般建议使用IN操作。如果限制性强的条件在主查询,则使用EXISTS操作。 2. NOT IN/EXISTS 在子查询中,NOT IN子句将执行一个内部的排序和合并。

    1.9K70

    Oracle中的分组查询与DML

    1、Group by 进行分组查询, group by 子句可以将数据分为若干个组 1.1 分组查询 注意: 出现在 SELECT 子句中的字段,如果不是包含在多行函数中,那么该字段必须同时在...最高工资和最低工资 select deptno, max(sal), min(sal) from emp group by deptno order by deptno; 1.2 带 where 的分组查询...注意: group by 子句要写到 where 子句的后面 a) 查询每个部门的人数和平均工资, 排除 10 部门 select deptno, count(*), avg(sal) from...emp where deptno10 group by deptno order by deptno; 1.3 带 having 的分组查询 注意: where 子句中不允许使用分组函数,...: from–>where–>group by–>select–>having–>order by a) 在 emp 表中,列出工资最小值小于 2000 的职位 select job, min(sal

    1.2K20

    msyql查询数据库中不存在的记录

    背景 有时候,需要往数据库里插入数据,这些数据,有些已经在MySQL中。但这种导入的工作,只是临时性的,又想专门写一个脚本去判断是否存在数据库,不存在就插入。...zhangsan | | 2 | wangwu | | 3 | zhaoliu | +----+----------+ 3 rows in set (0.00 sec) 查看存在的数据 你可以使用以下查询语句来判断..."zhangsan" 和 "lisi" 是否在数据库中.如果 "zhangsan" 和 "lisi" 存在于数据库中,那么可以查询将返回它们的名字。...'lisi'); +----------+ | name | +----------+ | zhangsan | +----------+ 1 row in set (0.00 sec) 查找不存在的数据...如果你想知道哪个名字不在数据库中,可以稍作修改,使用 NOT IN 来找出不在数据库中的名字 SELECT 'zhangsan' AS name WHERE 'zhangsan' NOT IN (SELECT

    27930

    Oracle 中的SELECT 关键字(查询、检索)

    通配符(A): * :代表0个或多个列 _ : 代表单个字符 % : 代表0个或多个字符 使用通配符的优点:书写方便、可以检索未知列 使用通配符的缺点:降低检索的性能 3....:select * from emp where exists(select *from dept where LOC = 'DALLAS'); 子查询中 LOC列存在DALLAS则执行父查询返回emp...我们经常需要直接从数据库中检索出转换、计算或格式化过的数据;而不是检索出数据,然后再在客户机应用程序中重新进行计算或格式化。...2000 union all select * from emp where deptno=20; 8.3 intersect(交集): 返回查询结果中相同的部分。...; 8.4 minus(差集): 返回在第一个查询结果中与第二个查询结果不相同的那部分记录。

    4.1K10

    mysql中的查询计划及sql语句性能分析

    通过explain可以分析查询语句或表结构的性能瓶颈。...select_type列的值主要有以下6种情况: ①、SIMPLE:简单的select查询,查询中不包含子查询或者UNION ②、PRIMARY:查询中若包含任何复杂的子查询,那么最外层的查询则被标记为...primary 图片 ③、SUBQUERY:在select或where中包含了子查询 ④、DERIVED:在from列表中包含的子查询被标记为derived(衍生),把结果放在临时表当中。...其它说明: 查询中若使用了覆盖索引,则该索引仅出现在key列表中。 覆盖索引:查询的字段和建立的字段刚好吻合,这种我们称为覆盖索引。...(需要建立临时表(temporary table)来暂存中间结果,出现这个 表示该条SQL语句性能较低,通常情况下需要进行优化) ③、Useing index:表示相应的select中使用了覆盖索引,避免访问了表中的数据行

    2.1K30

    谈谈SQL查询中回表对性能的影响

    : select id from user where name like ‘%foobar%’ order by created_at limit 10; 业务需要,LIKE 的时候必须使用模糊查询...要想搞清楚缘由,你需要理解本例中 SQL 查询的处理流程:当使用 limit 时,因为只是返回几条数据,所以优化器觉得采用一个满足 order by 的索引比较划算;当不使用 limit 时,因为要返回所有满足条件的数据...不过就算知道这些还是不足以解释为什么在本例中全表扫描反而快,实际上这是因为当使用索引的时候,除非使用了 covering index,否则一旦索引定位到数据地址后,这里会有一个「回表」的操作,形象一点来说...,就是返回原始表中对应行的数据,以便引擎进行再次过滤(比如本例中的 like 运算),一旦回表操作过于频繁,那么性能无疑将急剧下降,全表扫描没有这个问题,因为它就没用索引,所以不存在所谓「回表」操作。

    2.4K20

    在Oracle中,什么是闪回版本查询(Flashback Version Query)?

    题目部分 在Oracle中,什么是闪回版本查询(Flashback Version Query)?...答案部分 闪回版本查询(Flashback Version Query)是查询过去某个时间段或某个SCN段内表中数据的变化情况。闪回版本查询基于回滚(Undo)表空间中的回滚信息实现。...SCN段;AS OF用于指定闪回查询时查询的时间点或SCN。...在闪回版本查询的目标列中,可以使用下列几个伪列返回版本信息: l VERSIONS_STARTTIME:基于时间的版本有效范围的下界; l VERSIONS_STARTSCN:基于SCN的版本有效范围的下界...闪回版本查询注意事项: ① VERSIONS子句不能用于查询的表包括外部表、临时表和固定表。 ② 不能使用VERSIONS子句查询视图。但是,在视图定义中可使用VERSIONS子句。

    46230

    高级性能测试系列《26. 从mysql中查询出数据写入sqlite中,再从sqlite中查询出数据写入txt文件中。》

    目录 一、回顾 二、DDT数据驱动性能测试:jmeter + sqlite 1.csv\txt文件中的数据,怎么来的? 2.保存响应到本地的txt文件。...四、从mysql数据库中查询出数据,将查询到的数据写入sqlite数据库中。 五、从sqlite数据库中查询出所有的数据,将数据写入txt文件中。...二、DDT数据驱动性能测试:jmeter + sqlite DDT数据驱动性能测试:csv\txt文件。 1.csv\txt文件中的数据,怎么来的? 手工造。 数据库导出。...是否可以用jmeter把数据库中的数据导出来。 性能测试环境的数据库中,已经有一批账号,我想把用户表中的账号导出。 使用jmeter导出数据库中的数据。...五、从sqlite数据库中查询出所有的数据,将数据写入txt文件中。 图4:从mysql数据库中查询数据offset 1300 图4:teardown线程组:1个线程,循环次数是1。

    4K21
    领券