`
t22011787
  • 浏览: 75435 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

优化sql语句的若干方法

sql 
阅读更多
优化SQL语句的若干方法

1、操作符号: NOT IN操作符
此操作是强列推荐不使用的,因为它不能应用表的索引。

推荐方案:用NOT EXISTS 或(外连接+判断为空)方案代替 "IS NULL", "<>", "!=", "!>", "!<", "NOT", "NOT IN", "NOT LIKE", "LIKE '%500'",
因为他们不走索引全是表扫描。
NOT IN会多次扫描表,
使用EXISTS、NOT EXISTS、IN、LEFT OUTER JOIN来替代,特别是左连接,
而Exists比IN更快,最慢的是NOT操作。
使用in时,在IN后面值的列表中,将出现最频繁的值放在最前面,出现得最少的放在最后面,这样可以减少判断的次数



2、注意union和union all的区别。union比union all多做了一步distinct操作。能用union all的情况下尽量不用union。



3、查询时尽量不要返回不需要的行、列。另外在多表连接查询时,尽量改成连接查询,少用子查询。



4、尽量少用视图,它的效率低。对视图操作比直接对表操作慢,可以用存储过程来代替它。特别的是不要用视图嵌套,嵌套视图增加了寻找原始资料的难度。
我们看视图的本质:它是存放在服务器上的被优化好了的已经产生了查询规划的SQL。对单个表检索数据时,不要使用指向多个表的视图,
直接从表检索或者仅仅包含这个表的视图上读,否则增加了不必要的开销,查询受到干扰.



5、创建合理的索引,对于插入或者修改比较频繁的表,尽量慎用索引。因为如果表中存在索引,插入和修改时也会引起全表扫描。
索引一般使用于where后经常用作条件的字段上。



6、在表中定义字段或者存储过程、函数中定义参数时,将参数的大小设置为合适即可,勿设置太大。这样开销很大。


7、Between在某些时候比IN速度更快,Between能够更快地根据索引找到范围。select * from chineseresume where title in ('男','女')
Select * from chineseresume where between '男' and '女'是一样的。
由于in会在比较多次,所以有时会慢些。



8、ORACLE的解析器按照从右到左的顺序处理FROM子句中的表名
例如:表 TAB1 16,384 条记录
      表 TAB2 1      条记录
 
选择TAB2作为基础表 (最好的方法)
     select count(*) from tab1,tab2  
执行时间0.96秒
选择TAB2作为基础表 (不佳的方法)
     select count(*) from tab2,tab1  
执行时间26.09秒



9、ORACLE采用自下而上的顺序解析WHERE子句,
SELECT …
FROM EMP E
WHERE  SAL > 50000
AND    JOB = ‘MANAGER’
AND    25 < (SELECT COUNT(*) FROM EMP
             WHERE MGR=E.EMPNO);
低效,执行时间156.3秒
SELECT …
FROM EMP E
WHERE 25 < (SELECT COUNT(*) FROM EMP
             WHERE MGR=E.EMPNO)
AND    SAL > 50000
AND    JOB = ‘MANAGER’;
高效,执行时间10.6秒



10、没有必要时不要用DISTINCT和ORDER BY,它们增加了额外的开销。这些动作可以改在客户端执行。



14、一般在GROUP BY和HAVING字句之前就能剔除多余的行,所以尽量不要用它们来做剔除行的工作。
他们的执行顺序应该如下最优:select 的Where字句选择所有合适的行,Group By用来分组个统计行,Having字句用来剔除多余的分组。
这样Group By和Having的开销小,查询快.对于大的数据行进行分组和Having十分消耗资源。



15、 使用DECODE函数来减少处理时间
使用DECODE函数可以避免重复扫描相同记录或重复连接相同的表.
例如:
   SELECT COUNT(*),SUM(SAL)
   FROM EMP
   WHERE DEPT_NO = 0020
   AND ENAME LIKE ‘SMITH%’;
 
   SELECT COUNT(*),SUM(SAL)
   FROM EMP
   WHERE DEPT_NO = 0030
   AND ENAME LIKE ‘SMITH%’;

你可以用DECODE函数高效地得到相同结果
SELECT COUNT(DECODE(DEPT_NO,0020,’X’,NULL)) D0020_COUNT,
        COUNT(DECODE(DEPT_NO,0030,’X’,NULL)) D0030_COUNT,
        SUM(DECODE(DEPT_NO,0020,SAL,NULL)) D0020_SAL,
        SUM(DECODE(DEPT_NO,0030,SAL,NULL)) D0030_SAL
FROM EMP WHERE ENAME LIKE ‘SMITH%’;
 
类似的,DECODE函数也可以运用于GROUP BY 和ORDER BY子句中.


16、计算记录条数
     和一般的观点相反, count(*) 比count(1)稍快 , 当然如果可以通过索引检索,对索引列的计数仍旧是最快的. 例如 COUNT(EMPNO)



17、减少对表的查询
在含有子查询的SQL语句中,要特别注意减少对表的查询.
例如:
     低效
          SELECT TAB_NAME
          FROM TABLES
          WHERE TAB_NAME = ( SELECT TAB_NAME
                                FROM TAB_COLUMNS
                                WHERE VERSION = 604)
          AND DB_VER= ( SELECT DB_VER
                           FROM TAB_COLUMNS
                           WHERE VERSION = 604)
     高效
          SELECT TAB_NAME
          FROM TABLES
          WHERE  (TAB_NAME, DB_VER)
= ( SELECT TAB_NAME, DB_VER)
                   FROM TAB_COLUMNS
                   WHERE VERSION = 604)
 
     Update 多个Column 例子:
     低效:
           UPDATE EMP
           SET EMP_CAT = (SELECT MAX(CATEGORY) FROM EMP_CATEGORIES),
              SAL_RANGE = (SELECT MAX(SAL_RANGE) FROM EMP_CATEGORIES)
           WHERE EMP_DEPT = 0020;
     高效:
           UPDATE EMP
           SET (EMP_CAT, SAL_RANGE)
= (SELECT MAX(CATEGORY) , MAX(SAL_RANGE)
FROM EMP_CATEGORIES)
              HERE EMP_DEPT = 0020;
18、避免在索引列上使用NOT

我们要避免在索引列上使用NOT, NOT会产生在和在索引列上使用函数相同的
影响. 当ORACLE”遇到”NOT,他就会停止使用索引转而执行全表扫描.

低效: (索引失效)
SELECT …
FROM DEPARTMENT
WHERE DEPT_CODE IS NOT NULL;
 
高效: (索引有效)
SELECT …
FROM DEPARTMENT
WHERE DEPT_CODE >=0
分享到:
评论

相关推荐

    值对象转换成SQL语句

    为了防止SQL注入,应该使用预编译的SQL语句(如Java的PreparedStatement)或者使用ORM框架(如Hibernate、MyBatis)提供的安全方法来处理动态SQL。 在实际应用中,结合Bean使用值对象转换为SQL语句的方法可以提高...

    实现SQL优化的若干方法

    ### 实现SQL优化的若干方法 #### 一、引言 在现代信息技术中,数据库的性能直接影响着应用程序的响应时间和用户体验。SQL优化是一项关键的技术,它可以帮助我们提高查询效率、减少资源消耗,从而提升整体系统的...

    MySQL优化SQL语句的技巧

    MySQL优化SQL语句的技巧是数据库管理员和开发人员提高系统性能的关键技能。本文主要探讨了四种常见的SQL优化策略,旨在帮助开发者更好地理解和改进SQL查询性能。 1. **分解SQL**: 在面对复杂的SQL查询时,一个...

    SQL查询语句的练习

    存储过程是一组预编译的SQL语句,可以封装在一起并多次调用,提高代码复用性和安全性。触发器则在特定的数据库事件发生时自动执行,如INSERT、UPDATE或DELETE操作。 8. **事务管理** SQL支持事务,确保数据的一致...

    SQL性能优化专题分享

    Oracle作为一个功能强大的商业数据库管理系统,它的性能优化往往包括多方面的考量,比如索引、查询计划、并发控制、SQL语句的编写等。 3. 关于索引 - 索引是数据库中用于快速定位数据记录的重要数据结构。本分享中...

    Oracle语句优化规则汇总

    避免在SQL语句中直接拼接变量。 4. **减少行处理**:通过LIMIT和ROWNUM限制返回的行数,尤其是在联接和子查询中。这能减少内存占用和处理时间。 5. **合理使用JOIN操作**:避免在JOIN操作中使用笛卡尔积,尽量减少...

    一些经典的SQL语句和各大公司的面试题

    以下是一些经典的SQL语句以及各大公司在面试中可能会问到的问题,这些知识点对你的职业生涯至关重要。 1. **SQL基本操作**: - **SELECT**:查询是最常见的SQL操作,用于从数据库中获取数据。你可以通过指定字段、...

    优化Oracle库表设计的若干方法

    创建独立的表空间需要执行SQL语句,例如: ```sql CREATE TABLESPACE tablespace_name DATAFILE 'file_path' SIZE file_size AUTOEXTEND ON NEXT autoextend_size MAXSIZE max_size; CREATE INDEX TABLESPACE index_...

    sql 数据库学生信息系统实例

    例如,我们可以编写一个SQL语句插入一个新的学生信息: ```sql INSERT INTO 学生表 (学号, 姓名, 性别, 出生日期, 班级) VALUES ('001', '张三', '男', '1999-01-01', '1班'); ``` "删"(DELETE)操作用于删除学生...

    Oracle SQL优化实例讲解.pdf

    通过分析该视图中的数据,可以获得执行效率低下SQL语句的详细信息,便于优化。 10. 基于成本的优化CBO 成本基础优化器(CBO)是Oracle SQL优化器的一种,它基于统计信息和成本模型来决定执行计划。CBO会根据可能的...

    SQL随机提取N条记录

    在SQL(Structured Query ...以上就是关于“SQL随机抽取N条记录”的详细解释,这些方法可以帮助你从数据库中获取随机样本,无论是进行数据分析还是其他目的。记住,根据你使用的具体SQL方言,可能需要调整上述代码。

    oracle语句优化规则汇总

    二、优化SQL语句 1. **避免在WHERE子句中使用函数**:这可能导致无法使用索引,导致全表扫描。 2. **减少子查询**:尽量合并子查询,使用JOIN操作替代,减少查询复杂度。 3. **使用EXPLAIN PLAN分析查询**:通过...

    SqlserverTest_sql_

    2. 性能优化:合理设计索引、批量插入、使用存储过程、预编译SQL语句(SqlCommand的Prepare方法)等方法提升性能。 九、安全性 确保正确配置数据库权限,限制不必要的数据库访问,使用参数化查询避免SQL注入,定期...

    基于SQL的关系数据查询优化策略.pdf

    在本文中,作者通过分析数据库应用系统中常见的几种运算,提出了一系列优化SQL语句的策略,以提高系统运行速度。具体来说,文章提出了选择、投影、连接三种基本的关系运算,并讨论了它们的优化顺序,即优先执行选择...

    带复杂计算的金融领域自然语言查询的SQL生成.pdf

    该模型通过分析一类复杂计算查询(行计算查询)的特点,提出了一种基于分治的方法,即先将一个行计算查询分解为若干个子查询,分别针对每个子查询生成 SQL 语句,再将子查询的 SQL 语句组合在一起得到原始查询的 SQL...

    sql server 2005 Experiment1_sql server 2005

    SSMS提供了丰富的功能,如连接到数据库引擎,管理服务器,以及编写和执行SQL语句。在SSMS中,“已注册的服务器”允许你管理和监控多个服务器实例。工具菜单下的选项则可定制工作环境,包括界面布局、查询行为和源...

    数据库基本概念 ,常用数据库,sql server数据库,Access数据库,sql语句,数据库连接,数据库分页显示

    一个表通常由若干列组成,每列代表一个特定属性,而每一行则代表一条具体的记录。 - **记录**:即表格中的一行,表示一个完整的实体或实例的所有信息。 - **字段**(也称数据项):指表格中的一列,每一列代表实体的...

    基于Oracle数据库系统的性能优化与调整研究.pdf

    文章探讨了Oracle数据库系统性能优化与调整的若干关键技术和方法,内容涵盖SQL语句优化、内存分配调整和磁盘I/O优化等方面。 1. Oracle数据库查询优化 Oracle数据库查询优化是提升系统性能的重要途径,主要工作包括...

    oracle性能优化资料大全(更全最深)

    oracle专业优化文档,Oracle的SQL语句执行效率问题查找与解决方法文档,oracle性能优化总结文档,数据库设计方法文档,SQL语句全优化文档,数据库设计中的14个实用技巧文档,优化Oracle库表设计的若干方法等......

Global site tag (gtag.js) - Google Analytics