SQL2005性能分析一些细节功能你是否有用到?
时间:2022-03-14 04:35
原文:
我相信很多朋友对现在越来越大的数据量而感到苦恼,可是总要面对现实啊,包括本人在内的数据库菜鸟们在开发B/S程序时,往往只会关心自己的数据是否正确的查询出来,一旦自己写的程序哪天要花上十秒或者是一分种才会出来,此时就技穷了.如何优化成为菜鸟们的难题.本人不才,最近看了些园友关于数据库优化的文章,觉的有必要总结下,让更多像我一样只关心结果,并不关心质量的朋友少走些弯路.
一般根据大众分析SQL性能的基本方法:首先是看此SQL的执行IO成本,其次是看执行计划.
图一就是SQL执行时的IO等统计信息.包括本人在内的数据库菜鸟对于这种IO信息一般都不太关注,我们更加关注的时把查询的数据查询出来就OK,至于这些内部的执行情况我们并不关心.以至于在看到园友的相关数据库文章后,就会有如下问题:
它是分析SQL性能的重要指标,里面一般会包含执行语句的各部分开销占用比例情况.拿查询来说,它会非常清晰的显示出各种查询算法,查找索引,排序等占用的比例.开发员就可以根据这些参数来做些适当的优化方案.
如何实现:
第一:在执行语句前,按快捷键:Ctrl+M;第二:在菜单栏中点击图三中间的按钮即可.
第三:如何解决SQL中的共享锁产生的死锁.
有的时候,在一个复杂的查询事务中由于种种原因可能非常耗时,这里我说下我理解的可能原因:
原因一:数据量实在太多.原因二:查询语句本身有严重的性能问题.例如不合理的嵌套查询,子查询,不能充分利用索引等.
所以在查询中出现的死锁,我们一般会在查询的表名后面加上(nolock)的参数,但是总觉的这样做不爽,既不美观,也好像不治本,难免下次又忘记了,所以本人推荐以下解决方案:引用下MSDN推荐方案:使用基于行版本控制的隔离级别
行版本控制框架在 Microsoft SQL Server 中始终处于启用状态,并被多个功能使用。它除了提供基于行版本控制的隔离级别之外,还用于支持对触发器和多个活动结果集 (MARS) 会话的修改,以及 ONLINE 索引操作的数据读取。
基于行版本控制的隔离级别是在数据库级别上启用的。访问已启用数据库的对象的任何应用程序可以使用以下隔离级别运行查询:已提交读隔离级别,通过将 READ_COMMITTED_SNAPSHOT 数据库选项设置为 ON 来使用行版本控制,如下面的代码示例所示:
SET READ_COMMITTED_SNAPSHOT ON;
为 READ_COMMITTED_SNAPSHOT 启用数据库后,在已提交读隔离级别下运行的所有查询将使用行版本控制,这意味着读取操作不会阻止更新操作。
总结:虽然明白了这些基本的方法不一定能让你马上成为非常出色的数据库优化员,起码我们有了这个基础.天空任鸟飞,但我已飞过.重要的是过程,是分析问题的方法和理论.数据库优化的面太广,并非几篇短文就说的清的,本文的目的在于提醒现在还不关心SQL性能基本分析方法的朋友,知道总比不知道强.
注:
本文引用: MSDN