`
tianyuzhu
  • 浏览: 24746 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

SQL性能优化十条经验

阅读更多

1.查询的模糊匹配

尽量避免在一个复杂查询里面使用 LIKE '%parm1%'—— 红色标识位置的百分号会导致相关列的索引无法使用,最好不要用.

解决办法:

其实只需要对该脚本略做改进,查询速度便会提高近百倍。改进方法如下:

a、修改前台程序——把查询条件的供应商名称一栏由原来的文本输入改为下拉列表,用户模糊输入供应商名称时,直接在前台就帮忙定位到具体的供应商,这样在调用后台程序时,这列就可以直接用等于来关联了。

b、直接修改后台——根据输入条件,先查出符合条件的供应商,并把相关记录保存在一个临时表里头,然后再用临时表去做复杂关联

2.索引问题

在做性能跟踪分析过程中,经常发现有不少后台程序的性能问题是因为缺少合适索引造成的,有些表甚至一个索引都没有。这种情况往往都是因为在设计表时,没去定义索引,而开发初期,由于表记录很少,索引创建与否,可能对性能没啥影响,开发人员因此也未多加重视。然一旦程序发布到生产环境,随着时间的推移,表记录越来越多

这时缺少索引,对性能的影响便会越来越大了。

这个问题需要数据库设计人员和开发人员共同关注

法则:不要在建立的索引的数据列上进行下列操作:

◆避免对索引字段进行计算操作

◆避免在索引字段上使用not,<>,!=

◆避免在索引列上使用IS NULL和IS NOT NULL

◆避免在索引列上出现数据类型转换

◆避免在索引字段上使用函数

◆避免建立索引的列中使用空值。

3.复杂操作

部分UPDATE、SELECT 语句 写得很复杂(经常嵌套多级子查询)——可以考虑适当拆成几步,先生成一些临时数据表,再进行关联操作

4.update

同一个表的修改在一个过程里出现好几十次,如:

update table1
set col1=...
where col2=...;
update table1
set col1=...
where col2=...
......

象这类脚本其实可以很简单就整合在一个UPDATE语句来完成(前些时候在协助xxx项目做性能问题分析时就发现存在这种情况)

5.在可以使用UNION ALL的语句里,使用了UNION

UNION 因为会将各查询子集的记录做比较,故比起UNION ALL ,通常速度都会慢上许多。一般来说,如果使用UNION ALL能满足要求的话,务必使用UNION ALL。还有一种情况大家可能会忽略掉,就是虽然要求几个子集的并集需要过滤掉重复记录,但由于脚本的特殊性,不可能存在重复记录,这时便应该使用UNION ALL,如xx模块的某个查询程序就曾经存在这种情况,见,由于语句的特殊性,在这个脚本中几个子集的记录绝对不可能重复,故可以改用UNION ALL)

6.在WHERE 语句中,尽量避免对索引字段进行计算操作

这个常识相信绝大部分开发人员都应该知道,但仍有不少人这么使用,我想其中一个最主要的原因可能是为了编写写简单而损害了性能,那就不可取了

9月份在对XX系统做性能分析时发现,有大量的后台程序存在类似用法,如:

......
where trunc(create_date)=trunc(:date1)

虽然已对create_date 字段建了索引,但由于加了TRUNC,使得索引无法用上。此处正确的写法应该是

where create_date>=trunc(:date1) and create_date

或者是

where create_date between trunc(:date1) and trunc(:date1)+1-1/(24*60*60)

注意:因between 的范围是个闭区间(greater than or equal to low value and less than or equal to high value.),

故严格意义上应该再减去一个趋于0的小数,这里暂且设置成减去1秒(1/(24*60*60)),如果不要求这么精确的话,可以略掉这步。

7.对Where 语句的法则

7.1 避免在WHERE子句中使用in,not  in,or 或者having

可以使用 exist 和not exist代替 in和not in。

可以使用表链接代替 exist。Having可以用where代替,如果无法代替可以分两步处理。

例子

SELECT *  FROM ORDERS WHERE CUSTOMER_NAME NOT IN 
(SELECT CUSTOMER_NAME FROM CUSTOMER)

优化

SELECT *  FROM ORDERS WHERE CUSTOMER_NAME not exist 
(SELECT CUSTOMER_NAME FROM CUSTOMER)

7.2 不要以字符格式声明数字,要以数字格式声明字符值。(日期同样)否则会使索引无效,产生全表扫描。

例子使用:

SELECT emp.ename, emp.job FROM emp WHERE emp.empno = 7369;
不要使用:SELECT emp.ename, emp.job FROM emp WHERE emp.empno = ‘7369’

8.对Select语句的法则

在应用程序、包和过程中限制使用select * from table这种方式。看下面例子

使用SELECT empno,ename,category FROM emp WHERE empno = '7369‘
而不要使用SELECT * FROM emp WHERE empno = '7369'

9. 排序

避免使用耗费资源的操作,带有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL语句会启动SQL引擎 执行,耗费资源的排序(SORT)功能. DISTINCT需要一次排序操作, 而其他的至少需要执行两次排序

10.临时表

慎重使用临时表可以极大的提高系统性能

分享到:
评论

相关推荐

    高手详解SQL性能优化十条经验

    本文将深入探讨高手们在实践中总结的十条SQL性能优化经验。 1. **避免模糊匹配**:使用LIKE '%parm1%'可能导致索引失效,降低查询效率。解决方法可以是改进前端程序,提供下拉列表限制输入范围,或在后台先筛选出...

    sql性能优化十大要素(英文)

    接下来,文档详细介绍了十条SQL性能优化的关键要素: 1. 确保提供适当的统计信息。这是性能优化的基础,确保数据库优化器能够根据准确的统计信息制定出高效的执行计划。 2. 尽可能推广阶段2和阶段1谓词。即优化...

    SQL使用技巧十条建议

    ### SQL使用技巧十条建议 #### 一、使用索引提升查询速度 **索引**是数据库中一种重要的数据结构,其主要目的是为了加速查询过程。当数据库接收到一个查询请求时,它会根据索引来定位数据,从而避免了全表扫描,...

    Oracle数据库日常维护方案书.pdf

    本项目的总体方案是为 Oracle 数据库提供一个完整的日常维护方案,包括数据库性能优化、数据库安全检查、数据备份和恢复、数据库优化等几个方面。 3.1 数据库性能优化 数据库性能优化是 Oracle 数据库日常维护的...

    Mysql千万级别数据优化方案

    因此,我们需要优化我们的 SQL 语句,以提高查询速度。 例如,我们可以使用以下优化后的 SQL 语句: SELECT * FROM v_history_data INNER JOIN (SELECT fid FROM t_history_data LIMIT 5000000, 10) AS a ON v_...

    C# DataGridView的数据分页显示

    7. **性能优化**:为了提高性能,避免一次性加载所有数据,应确保只加载当前页的数据。此外,考虑使用存储过程或者参数化查询,以防止SQL注入攻击。 8. **异常处理**:别忘了添加适当的异常处理代码,以确保在出现...

    Oracle数据库日常管理方案精样本.docx

    例如,通过查询v$sqltext和v$sql_plan,可以找出执行全表扫描的SQL语句,这些可能是性能优化的目标。 在数据库出现异常时,物理构造和逻辑构造的故障解决方法是必不可少的。物理构造故障可能涉及磁盘错误或硬件故障...

    ORACLE_数据库日常工作维护知识总结.pdf

    - 查找前十条性能差的SQL:通过监控和分析,优化执行效率低下的SQL语句。 - 获取等待时间最多的系统等待事件:确定导致性能问题的主要系统等待事件。 - 检查运行很久的SQL:监控并优化长时间运行的SQL语句。 - ...

    Oracle数据库日常维护手册.pdf

    ##### 6.3 查找前十条性能差的SQL - **SQL命令**:`SELECT sql_id, sql_text, executions, elapsed_time, cpu_time FROM v$sqlarea ORDER BY elapsed_time DESC LIMIT 10;` - 此命令用于找出执行时间最长的前十个...

    Oracle数据库日常维护手册v1.8.pdf

    综上所述,Oracle数据库的日常维护工作涵盖了从基础状态检查、日志文件监控、对象和资源使用情况监控、备份检查到性能优化以及安全检查等多个层面,需要数据库管理员(DBA)细致地进行管理和调整,确保数据库的稳定...

    ORACLE数据库日常维护知识

    6.2 查找前十条性能差的sql:分析执行时间较长的SQL语句,优化查询以提升性能。 6.3 等待时间最多的5个系统等待事件的获取:了解系统中最常见的等待事件,对数据库进行相应的优化。 6.4 检查运行很久的SQL:监控...

    ORACLE_日常维护知识大全

    查找前十条性能差的sql** - 通过查询`v$sql`视图并排序,找出执行效率低下的SQL语句。 - **6.4. 等待时间最多的5个系统等待事件的获取** - 查询`v$system_event`视图来查找最耗费时间的等待事件。 - **6.5. ...

    Oracle DBA日常巡检最佳实践

    **4.3 查找前十条性能差的sql** - **目的**:优化性能最差的SQL语句,提高整体性能。 - **方法**:使用`DBMS_SQL_MONITOR`包来查找性能最差的SQL语句。 **4.4 等待时间最多的5个系统等待事件的获取** - **目的**...

    ORACLE数据库日常工作维护知识总结.pdf

    查找前十条性能差的sql** - **方法**: 使用 `V$SQL_PLAN_STATISTICS_ALL` 视图并结合统计信息来查找性能较差的SQL语句。 **6.4. 等待时间最多的5个系统等待事件的获取** - **方法**: 通过查询 `V$SYSSTAT` 视图...

    iso面试2016

    12. **性能优化**: - 减少内存分配和释放。 - 使用懒加载和缓存。 - 图片压缩和分辨率适配。 - 使用异步操作避免阻塞主线程。 - 利用GCD优化多线程。 13. **JSON解析优化**: - 批量解析:一次加载大量数据...

    Java开发者的十大戒律

    综上所述,这十条戒律涵盖了从代码风格、框架选择到安全性等多个方面,都是Java开发者在日常工作中应当遵循的重要原则。遵循这些戒律不仅能帮助开发者写出高质量的代码,还能促进团队的合作与项目的成功。

    iOS面试题总结

    #### 十二、性能优化方法 - **减少不必要的内存分配**:避免频繁创建临时对象。 - **优化算法复杂度**:选择合适的算法和数据结构。 - **使用缓存**:缓存计算结果,减少重复计算。 - **异步加载**:使用多线程或...

    php接口实现拖拽排序功能

    在Web开发中,拖拽排序是一项实用的功能,它允许用户通过直观的拖放操作来调整列表中的元素顺序。... 首先,我们要理解拖拽排序的基本逻辑。...记住,良好的代码组织和性能优化对于提高用户体验至关重要。

Global site tag (gtag.js) - Google Analytics