• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >数据库其它 > 常用SQL语句优化技巧总结【经典】

常用SQL语句优化技巧总结【经典】

作者:FrankYou 字体:[增加 减小] 来源:互联网 时间:2017-05-11

FrankYou通过本文主要向大家介绍了sql语句优化技巧,sql查询语句技巧,sql语句大全经典教程,经典sql语句面试题,经典sql语句大全等相关知识,希望本文的分享对您有所帮助

本文实例总结了常用SQL语句优化技巧。分享给大家供大家参考,具体如下:

除了建立索引之外,保持良好的SQL语句编写习惯将会降低SQL性能问题发生。

①通过变量的方式来设置参数

好:

stringsql = "select * from people p where p.id = ? ";
</div>

坏:

stringsql = "select * from people p where p.id = "+id;
</div>

数据库的SQL文解析和执行计划会保存在缓存中,但是SQL文只要有变化,就得重新解析。

“…where p.id = ”+id的方式在id值发生改变时需要重新解析,这会耗费时间。

②不要使用select *

好:

stringsql = "select people_name,pepole_age from people ";
</div>

坏:

stringsql = "select * from people ";
</div>

使用select *的话会增加解析的时间,另外会把不需要的数据也给查询出来,数据传输也是耗费时间的,

比如text类型的字段通常用来保存一些内容比较繁杂的东西,如果使用select *则会把该字段也查询出来。

③谨慎使用模糊查询

好:

stringsql = "select * from people p where p.id like 'parm1%' ";
</div>

坏:

stringsql = "select * from people p where p.id like '%parm1%' ";
</div>

当模糊匹配以%开头时,该列索引将失效,若不以%开头,该列索引有效。

④不要使用列号

好:

stringsql = "select people_name,pepole_age from people order by name,age";
</div>

坏:

stringsql = "select people_name,pepole_age from people order by 6,8";
</div>

使用列号的话,将会增加不必要的解析时间。

⑤优先使用UNION ALL,避免使用UNION

好:

stringsql = "select name from student union all select name from teacher";
</div>

坏:

stringsql = "select name from student union select name from teacher";
</div>

UNION 因为会将各查询子集的记录做比较,故比起UNION ALL ,通常速度都会慢上许多。一般来说,如果使用UNION ALL能满足要求的话,务必使用UNION ALL。还有一种情况,如果业务上能够确保不会出现重复记录。

⑥在where语句或者order by语句中避免对索引字段进行计算操作

好:

stringsql = "select people_name,pepole_age from people where create_date=date1 ";
</div>

坏:

stringsql = "select people_name,pepole_age from people where trunc(create_date)=date1";
</div>

当在索引列上进行操作之后,索引将会失效。正确做法应该是将值计算好再传入进来。

⑦使用not exist代替not in

好:

stringsql = "select * from orders where customer_name not exist (select customer_name from customer)";
</div>

坏:

stringsql = "select * from orders where customer_name not in(select customer_name from customer)";
</div>

如果查询语句使用了not in 那么内外表都进行全表扫描,没有用到索引;而not extsts 的子查询依然能用到表上的索引。

⑧ exist和in的区别

in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询。因此,in用到的是外表的索引, exists用到的是内表的索引。

如果查询的两个表大小相当,那么用in和exists差别不大。

如果两个表中一个较小,一个是大表,则子查询表大的用exists,子查询表小的用in:

例如:表A(小表),表B(大表)

1:

select * from A where cc in (select cc from B)

</div>

效率低,用到了A表上cc列的索引;

select * from A where exists(select cc from B where cc=A.cc)

</div>

效率高,用到了B表上cc列的索引。

2:

select * from B where cc in (select cc from A)

</div>

效率高,用到了B表上cc列的索引;

select * from B where exists(select cc from A where cc=B.cc)

</div>

效率低,用到了A表上cc列的索引。

⑨避免在索引列上做如下操作:

◆避免在索引字段上使用<>,!=
◆避免在索引列上使用IS NULL和IS NOT NULL
◆避免在索引列上出现数据类型转换(比如某字段是String类型,参数传入时是int类型)

当在索引列上使用如上操作时,索引将会失效,造成全表扫描。

⑩复杂操作可以考虑适当拆成几步

有时候会有通过一个SQL语句来实现复杂业务的例子出现,为了实现复杂的业务,嵌套多级子查询。造成SQL性能问题。对于这种情况可以考虑拆分SQL,通过多个SQL语句实现,或者把部分程序能完成的工作交给程序完成。

PS:这里再为大家推荐2款SQL在线工具供大家参考使用:

SQL在线压缩/格式化工具:
http://tools.weikejianghu.com/code/sql_format_compress

sql代码在线格式化美化工具:
http://tools.weikejianghu.com/code/sqlcodeformat

希望本文所述对大家数据库程序设计有所帮助。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 常用SQL语句优化技巧总结【经典】

相关文章

  • 2017-05-11详解SQLite中的查询规划器
  • 2017-05-11SQL中NTEXT字段内容显示&lt;long text&gt;的原因
  • 2017-05-11mysql "group by"与"order by"的研究--分类中最新的内容
  • 2017-05-11带参数的sql和不带参数的sql存储过程区别第1/2页
  • 2017-05-11海量数据库的查询优化及分页算法方案集合2/2
  • 2017-05-11node-mysql中防止SQL注入的方法总结
  • 2017-05-11MySQL与Oracle数据类型对应关系(表格形式)
  • 2017-05-11OLEDB和ODBC的区别(优缺点)
  • 2017-05-11复杂系统中的用户权限数据库设计解决方案
  • 2017-05-11数据库测试 实用技巧及测试方法

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • mybatis keyproperty 总是返回1
    • update 子查询使用介绍
    • mysql、mssql及oracle分页查询方法详解
    • telnet连接操作memcache服务器详解
    • 大数据量,海量数据处理方法总结
    • 如何取得一个表的所有字段名用逗号分割
    • Navicat for MySQL 乱码问题解决方法
    • SQL注入之基于布尔的盲注详解
    • 什么是数据库索引 有哪些类型和特点
    • 比较实用SQL语句总结

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有