2022年数据库查询性能优化参照 .pdf

上传人:H****o 文档编号:39892519 上传时间:2022-09-08 格式:PDF 页数:4 大小:42.48KB
返回 下载 相关 举报
2022年数据库查询性能优化参照 .pdf_第1页
第1页 / 共4页
2022年数据库查询性能优化参照 .pdf_第2页
第2页 / 共4页
点击查看更多>>
资源描述

《2022年数据库查询性能优化参照 .pdf》由会员分享,可在线阅读,更多相关《2022年数据库查询性能优化参照 .pdf(4页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。

1、数据库查询性能优化1合理使用索引索引是数据库中重要的数据结构,它的根本目的就是为了提高查询效率。索引的使用原则如下:对聚集索引使用整型键。另外,在唯一列、非空列或 identity 列上创建聚集索引可以获得性能收益。在查询经常用到的所有列上创建非聚集索引。在经常进行连接,但没有指定为外键的列上建立索引,而不经常连接的字段则由优化器自动生成索引。在频繁进行排序或分组(即进行groupby或orderby 操作)的列上建立索引。在条件表达式中经常用到的不同值较多的列上建立检索,在不同值少的列上不要建立索引。例如在用户表的“性别”列上只有“男”与“女”两个不同值,因此不要建立索引。如果建立索引反而会

2、严重降低更新速度。如果要排序的列有多个,可以在这些列上建立复合索引(compoundindex)。当数据库表更新大量数据后,删除并重建索引可以提高查询速度。2避免或简化排序应当简化或避免对大型表进行重复的排序。当能够利用索引自动以适当的次序产生输出时,优化器就避免了排序的步骤。以下是一些影响因素:索引中不包括一个或几个待排序的列;groupby 或orderby 子句中列的次序与索引的次序不一样;3避免对大型表进行全表顺序扫描在嵌套查询中,对表的顺序扫描会使查询效率急剧下降。避免这种情况的主要方法是对连接的列建立索引。尽管在所有的检查列上都有索引,但某些形式的 where子句强迫优化器使用顺序

3、存取。如下面的查询将强迫对 orders表执行顺序扫描:select*from orders where(customer_num=104 and order_num 1001)or order_num=1008虽然在 customer_num和order_num 上建了索引,但是在上面的语句中优化器还是会使用顺序扫描整个表。因为这个语句要检索的是分离的行的集合,所以应该改为如下语句:select*from orders where customer_num=104 and order_num 1001 名师资料总结-精品资料欢迎下载-名师精心整理-第 1 页,共 4 页 -union hse

4、lect*from orders wher eorder_num=1008 h这样就能利用索引来处理查询。4避免使用相关的子查询一个列同时在主查询和where子句中的查询中出现,很可能当主查询中的列值改变之后,子查询必须重新查询一次。查询嵌套层次越多,效率越低,因此应当尽量避免子查询。如果子查询不可避免,那么要在子查询中过滤掉尽可能多的行。5避免使用通配符匹配like关键字支持通配符匹配。但这种匹配特别耗费时间。例如:select*from customer where zipcode like “98_”即使在 zipcode列上建立了索引,在这种情况下也还是采用顺序扫描的方式。如果把语句改

5、为select*from customer where zipcode “98000”,在执行查询时就会利用索引来查询,大大提高速度。6 避免在 where子句使用数据转换和串操作等函数操作例如语句:select*from users where rtrim(username)=nametest,在where子句中使用了函数,因而这个语句不会使用索引,而会进行全表扫描。应该改成:select*from users where username=nametest 7避免在经常被更新的列建立索引,会严重影响性能。因为每次更新操作,所有的索引都必须做相应的调整。另外,所有的分页操作都被记录在日志中,

6、这也会增加I/O操作。8避免在经常更新的列上建立聚集索引。因为这会引起整行的移动。9尽量在 where 子句中少用 OR和IN。可以考虑将其使用Union分成几个子查询。10避免在 where子句中使用 NOT、或!=运算符。因为这会引起全表扫描。数据库查询性能优化1合理使用索引索引是数据库中重要的数据结构,它的根本目的就是为了提高查询效率。索引的使用原则如下:对聚集索引使用整型键。另外,在唯一列、非空列或 identity 列上创建聚集索引可以获得性能收益。在查询经常用到的所有列上创建非聚集索引。在经常进行连接,但没有指定为外键的列上建立索引,而不经常连接名师资料总结-精品资料欢迎下载-名师

7、精心整理-第 2 页,共 4 页 -的字段则由优化器自动生成索引。在频繁进行排序或分组(即进行groupby或orderby 操作)的列上建立索引。在条件表达式中经常用到的不同值较多的列上建立检索,在不同值少的列上不要建立索引。例如在用户表的“性别”列上只有“男”与“女”两个不同值,因此不要建立索引。如果建立索引反而会严重降低更新速度。如果要排序的列有多个,可以在这些列上建立复合索引(compoundindex)。当数据库表更新大量数据后,删除并重建索引可以提高查询速度。2避免或简化排序应当简化或避免对大型表进行重复的排序。当能够利用索引自动以适当的次序产生输出时,优化器就避免了排序的步骤。以

8、下是一些影响因素:索引中不包括一个或几个待排序的列;groupby 或orderby 子句中列的次序与索引的次序不一样;3避免对大型表进行全表顺序扫描在嵌套查询中,对表的顺序扫描会使查询效率急剧下降。避免这种情况的主要方法是对连接的列建立索引。尽管在所有的检查列上都有索引,但某些形式的 where子句强迫优化器使用顺序存取。如下面的查询将强迫对 orders表执行顺序扫描:select*from orders where(customer_num=104 and order_num 1001)or order_num=1008虽然在 customer_num和order_num 上建了索引,但

9、是在上面的语句中优化器还是会使用顺序扫描整个表。因为这个语句要检索的是分离的行的集合,所以应该改为如下语句:select*from orders where customer_num=104 and order_num 1001 union hselect*from orders wher eorder_num=1008 h这样就能利用索引来处理查询。4避免使用相关的子查询一个列同时在主查询和where子句中的查询中出现,很可能当主查询中的列值改变之后,子查询必须重新查询一次。查询嵌套层次越多,效率越低,因此应当尽量避免子查询。如果子查询不可避免,那么要在子查询中过滤掉尽可能多的行。5避免使用

10、通配符匹配like关键字支持通配符匹配。但这种匹配特别耗费时间。例如:名师资料总结-精品资料欢迎下载-名师精心整理-第 3 页,共 4 页 -select*from customer where zipcode like “98_”即使在 zipcode列上建立了索引,在这种情况下也还是采用顺序扫描的方式。如果把语句改为select*from customer where zipcode “98000”,在执行查询时就会利用索引来查询,大大提高速度。6 避免在 where子句使用数据转换和串操作等函数操作例如语句:select*from users where rtrim(username)=

11、nametest,在where子句中使用了函数,因而这个语句不会使用索引,而会进行全表扫描。应该改成:select*from users where username=nametest 7避免在经常被更新的列建立索引,会严重影响性能。因为每次更新操作,所有的索引都必须做相应的调整。另外,所有的分页操作都被记录在日志中,这也会增加I/O操作。8避免在经常更新的列上建立聚集索引。因为这会引起整行的移动。9尽量在 where 子句中少用 OR和IN。可以考虑将其使用Union分成几个子查询。10避免在 where子句中使用 NOT、或!=运算符。因为这会引起全表扫描。写了一个程序来看看多种排序算法的

12、效率问题,用于比较的排序算法有:1,冒泡排序 2,双向冒泡排序 3,选择排序 4,双端选择排序,5,插入排序 6,快速排序 7,希尔排序。这些排序算法都是在网上去找的,可不是我写的,经过简单测试,所以算法运行结果正确。我写了一个小程序,运行后如下:下面是对这些排序算法的数据总结:1,对于一个长度为 5000的数组排序,冒泡排序最慢,其次是双向冒泡排序,其他的都一般,快速排序最快!2,对于一个长度为 10000的数组排序还是冒泡排序最慢,其次是双向冒泡排序,快速排序的速度已经不是其他排序一个数量级的了!快啊!3,对于一个长度为 15000的数组排序,还是冒泡排序最慢,其次是双向冒泡排序。快速排序还是那么的快啊!4,对于一个长度为 20000的数组排序,冒泡,双向冒泡,双端选择,选择,插入,名列前五慢,快速排序还是不动声色,佩服!5,对于一个长度为 30000的数组排序,除了快速排序还是那么快以外其他所以排序算法都很慢了!名师资料总结-精品资料欢迎下载-名师精心整理-第 4 页,共 4 页 -

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 技术资料 > 技术总结

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知得利文库网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号-8 |  经营许可证:黑B2-20190332号 |   黑公网安备:91230400333293403D

© 2020-2023 www.deliwenku.com 得利文库. All Rights Reserved 黑龙江转换宝科技有限公司 

黑龙江省互联网违法和不良信息举报
举报电话:0468-3380021 邮箱:hgswwxb@163.com