`
jsntghf
  • 浏览: 2542642 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

高效率的SQL语句

阅读更多

 1、Where子句中的连接顺序

 

ORACLE采用自下而上的顺序解析WHERE子句。 

根据这个原理,表之间的连接必须写在其他WHERE条件之前,那些可以过滤掉最大数量记录的条件必须写在WHERE子句的末尾。 

 

举例: 

(低效) 

select ... from table1 t1 where t1.sal > 300 and t1.jobtype = '0001' and 20 < (select count(*) from table1 t2 where t2.pno = t1.tno); 

 

(高效) 

select ... from table1 t1 where 20 < (select count(*) from table1 t2 where t2.pno = t1.tno and t1.sal > 300 and t1.jobtype = '0001'); 

 

2、Select子句中避免使用“*”

 

当你想在select子句中列出所有的column时,使用动态SQL列引用 ‘*' 是一个方便的方法。不幸的是,这是一个非常低效的方法。 

 

实际上,ORACLE在解析的过程中,会将 '*' 依次转换成所有的列名,这个工作是通过查询数据字典完成的,这意味着将耗费更多的时间。 

 

3、减少访问数据库的次数

 

当执行每条SQL语句时,ORACLE在内部执行了许多工作: 

解析SQL语句、估算索引的利用率、绑定变量、读数据块等等。 

由此可见,减少访问数据库的次数,就能实际上减少ORACLE的工作量。 

 

举例: 

题目——我要查找编号为0001、0002学生的信息。 

(低效) 

select name,age,gender,address from t_student where id = '0001'; 

select name,age,gender,address from t_student where id = '0002'; 

 

(高效) 

select a.name,a.age,a.gender,a.address,b.name,b.age,b.gender,b.address from t_student a,t_student b where a.id = '0001' and b.id = '0002'; 

 

4、使用Decode函数来减少处理时间

 

使用DECODE函数可以避免重复扫描相同记录或重复连接相同的表。 

 

举例: 

(低效) 

select count(*), sum(banace) from table1 where dept_id = '0001' and name like 'anger%'; 

select count(*), sum(banace) from table1 where dept_id = '0002' and name like 'anger%'; 

 

(高效) 

select count(decode(dept_id,'0001','XYZ',null)) count_01,count(decode(dept_id,'0002','XYZ',null)) count_02, 

sum(decode(dept_id,'0001',dept_id,null)) sum_01,sum(decode(dept_id,'0002',dept_id,null)) sum_02 

from table1 

where name like 'anger%'; 

 

5、整合简单、无关联的数据库访问 

 

如果你有几个简单的数据库查询语句,你可以把它们整合到一个查询中(即使它们之间没有关系) 

 

举例: 

(低效) 

select name from table1 where id = '0001'; 

select name from table2 where id = '0001'; 

select name from table3 where id = '0001'; 

 

(高效) 

select t1.name, t2.name, t3.name 

    from table1 t1, table2 t2, table3 t3 

    where t1.id(+) = '0001' and t2.id(+) = '0001' and t3.id(+) = '0001' 

【注:上面例子虽然高效,但是可读性差,需要量情而定啊!】 

 

6、删除重复记录

 

最高效的删除重复记录方法(因为使用了ROWID) 

 

举例: 

delete from table1 t1 

where t1.rowid > (select min(t2.rowid) from table1 t2 where t1.id = t2.id); 

 

7、尽量不要使用having子句,可以考虑用where替换

 

having只会在检索出所有记录之后才对结果集进行过滤,这个处理需要排序、总计等操作。如果能通过where子句限制记录的数目,那就能减少这方面的开销。 

 

8、尽量用表的别名

 

当在SQL语句中连接多个表时,请使用表的别名并把别名前缀于每个Column上。 

这样一来,就可以减少解析的时间并减少那些由Column歧义引起的语法错误。 

 

9、用exists替代in

 

在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。 

在这种情况下,使用exists(或not exists)通常将提高查询的效率。 

 

举例: 

(低效) 

select ... from table1 t1 where t1.id > 10 and pno in (select no from table2 where name like 'www%'); 

 

(高效) 

select ... from table1 t1 where t1.id > 10 and exists (select 1 from table2 t2 where t1.pno = t2.no and name like 'www%'); 

 

10、用not exists替代not in

 

在子查询中,not in子句将执行一个内部的排序和合并。 

无论在哪种情况下,not in都是最低效的 (因为它对子查询中的表执行了一个全表遍历)。为了避免使用not in,我们可以把它改写成外连接(Outer Joins)或not exists。 

 

11、用exists替换distinct

 

当提交一个包含一对多表信息的查询时,避免在select子句中使用distinct,一般可以考虑用exists替换 

 

举例: 

(低效) 

select distinct d.dept_no, d.dept_name from t_dept d, t_emp e where d.dept_no = e.dept_no; 

 

(高效) 

select d.dept_no, d.dept_name from t_dept d where exists (select 1 from t_emp where d.dept_no = e.dept_no); 

 

exists使查询更为迅速,因为RDBMS核心模块将在子查询的条件一旦满足后,立刻返回结果。

 

12、用表连接替换exists 

通常来说,采用表连接的方式比exists更有效率。 

 

举例: 

(低效) 

select ename from emp e where exists (select 1 from dept where dept_no = e.dept_no and dept_cat = 'W'); 

 

(高效) 

select ename from dept d, emp e where e.dept_no = d.dept_no and dept_cat = 'W'; 

 

13、避免在索引列上使用is null和is not null 

 

避免在索引中使用任何可以为空的列,ORACLE将无法使用该索引。 

对于单列索引,如果列包含空值,索引中将不存在此记录; 

对于复合索引,如果每个列都为空,索引中同样不存在此记录; 

如果至少有一个列不为空,则记录存在于索引中。 

 

举例: 

如果唯一性索引建立在表的A列和B列上,并且表中存在一条记录的A,B值为(123,null)。ORACLE将不接受下一条具有相同A,B值(123,null)的记录插入,然而如果所有的索引列都为空,ORACLE将认为整个键值为空。因此你可以插入1000条具有相同键值的记录,当然它们都是空! 因为空值不存在于索引列中,所以WHERE子句中对索引列进行空值比较将使ORACLE停用该索引。 

 

14、复杂的sql,最好去看下它的执行计划,这样有利于你分析知道自己的sql效率如何。

分享到:
评论

相关推荐

    数据库培训高效率sql语句基础.ppt

    【数据库培训高效率sql语句基础】 在数据库系统中,衡量效率主要依据响应时间和吞吐量。在系统开发初期,由于数据量较少,SQL语句的性能差异可能不太明显,但随着数据的增长,高效的SQL语句对提升系统响应速度至关...

    数据库培训-高效率sql语句基础.pptx

    【数据库培训-高效率sql语句基础】 在数据库系统中,效率是衡量其性能的关键指标,这主要体现在响应时间和吞吐量上。响应时间是指系统处理请求的速度,而吞吐量则是指单位时间内系统能处理的请求量。在开发阶段,...

    如何写出高效率的SQL语句--SQL优化技巧

    如何写出高效率的SQL语句--SQL优化技巧 SQL 优化技巧是提高数据库性能的关键所在。编写高效率的 SQL 语句需要对索引的机制有一定了解,以下是关于索引的知识点: 索引的优点和局限 索引可以提高查询的效率,但会...

    分享三种高效率SQL语句分页方法

    以下是三种常用的高效率SQL语句分页方法: 1. **基于行号的分页(利用自增ID)** 这种方法适用于表中存在自动增长的ID字段。首先,定义两个变量Page和PageCount,Page表示当前页数,PageCount表示每页的数据条数。...

    自动生成SQL语句_C#_sql_

    本文将深入探讨如何在C#中自动生成SQL语句,以提高开发效率并减少手动编写SQL可能导致的错误。 一、Entity Framework与自动SQL生成 1. Entity Framework(EF)是微软提供的一个开源ORM(对象关系映射)框架,它...

    arcgis中的sql语句

    ### ArcGIS中的SQL语句详解 #### 一、SQL在ArcGIS中的角色与应用 SQL,全称为Structured Query Language,即结构化查询语言,是专为数据库设计的一种标准语言,用于管理和操作数据库中的数据。在ArcGIS环境中,SQL...

    oracle 查看当前会话执行的sql语句

    除了查看SQL语句本身,我们还需要关注会话的等待事件,这些事件可能会影响SQL语句的执行效率。 ```sql -- 查询当前会话的等待事件 select event, count(*) from v$session where event not in ('SQL*...

    SQL语句辅助工具

    总结来说,"SQL语句辅助工具"是一个实用的开发辅助软件,通过将SQL语句转换为C#代码,简化了数据库操作的过程,提高了开发效率,同时也降低了出错的可能性。对于使用C#和SQL的开发人员来说,这是一款值得拥有的工具...

    SQL 语句大全 SQL 语句大全

    - **存储过程**:预编译的SQL语句集合,可封装复杂的业务逻辑,提高效率和安全性。 - **触发器**:在特定数据库操作(如INSERT、UPDATE或DELETE)发生时自动执行的代码段。 9. **窗口函数** - **ROW_NUMBER()、...

    泛微系统SQL语句大全

    SQL语句可以用于跟踪流程状态、查询历史记录、分析流程效率等。例如,通过`JOIN`操作结合流程表和任务表,可以获取某个任务的所有处理人及他们的处理时间。 3. **效率排名SQL**: - 效率排名通常涉及对员工、部门...

    Sql语句生成器

    8. **定制和配置**:高级的Sql语句生成器允许用户自定义输出格式,如添加注释、设置编码格式,甚至可以调整SQL语句的顺序以优化执行效率。 9. **错误处理和报告**:在迁移过程中,工具应能捕获和报告任何错误,便于...

    SQL语句格式化工具

    总之,SQL语句格式化工具是提高SQL代码质量和团队效率的有效工具,尤其是在Windows环境下,丰富的选择和优秀的集成性使其成为开发者不可或缺的助手。通过合理利用这些工具,可以显著提升SQL编程的工作体验。

    泛型封装的sql语句

    当业务需求变化时,我们只需修改实体类或调整泛型类的方法,而无需修改大量的SQL语句,这无疑提高了开发效率。 总之,泛型封装的SQL语句是利用泛型特性来优化数据库操作的有效手段。它将SQL语句的构建与业务逻辑...

    高级SQL语句

    ### 高级SQL语句详解 #### 知识点一:高级SQL语句与数据处理 高级SQL语句是数据库管理中的重要工具,用于执行复杂的数据检索、更新和分析任务。这些语句超越了基本的SELECT、INSERT、UPDATE和DELETE命令,涵盖了更...

    SQL语句基础教程

    SQL语句基础教程 SQL(Structured Query Language)是一种特殊目的语言,用于管理关系数据库管理系统(RDBMS)。SQL语句基础教程旨在帮助新手和需要复习SQL的资料仓储业界老将,学习SQL基础知识和语法。 SQL指令 -...

    压测Oracle的SQL语句的性能情况

    标题"压测Oracle的SQL语句的性能情况"暗示了我们关注的是在高负载情况下,Oracle数据库处理SQL查询的能力。压力测试(Pressure Testing)是一种评估系统在极端工作条件下表现的方法,通过模拟大量并发用户执行SQL...

    Sql语句自动生成器

    总结来说,SQL语句自动生成器是提高数据库管理效率、降低错误率的有效工具。它降低了SQL学习曲线,使得数据库操作更加便捷,尤其适合初学者和需要快速处理大量SQL语句的开发者。通过“SQL语句生成器.exe”这个执行...

    sql语句自动生成器

    通过使用这样的工具,用户不仅可以提高工作效率,还能在实践中学习和理解SQL语句的构造和作用。对于初学者来说,它是一个很好的学习辅助工具,能帮助他们逐步掌握SQL的精髓。同时,对于经验丰富的开发者,它则是一个...

    SQL语句基础PPT

    4. **存储过程**: 存储过程是预编译的SQL语句集合,可重复使用,提高执行效率,减少网络通信。 5. **触发器**: 触发器是自动执行的程序,当特定的数据库操作(如INSERT、UPDATE、DELETE)发生时,会触发相应动作。 ...

Global site tag (gtag.js) - Google Analytics