很多年前,笔者那时刚从广东技术师范学院(现为广东技术师范大学,以前为广东民族学院)的计算机科学学院计算机科学与技术(师范)专业(广东专插本,本科插本生,跨专业)毕业不久,还没怎么了解索引和执行计划这些知识,而遇到财务某系统计算佣金特别慢的性能问题。那时通过百度,有目的性,又有点盲目地查找相关数据库性能优化的技巧,其中有一个技巧就用上了,效果也还可以,分享给大家:
  Step 1:使用Sql Server自带的性能工具【Profiler】,抓取系统运行的SQL语句并保存为跟踪文件。
  Step 2:使用Sql Server自带的性能工具【数据库引擎优化顾问】,对Step 1抓取的跟踪文件进行自动分析,会自动给出增加索引和统计信息之类的建议,直接应用到数据库就可以。
  现在回过头来看,当时这样操作确实大大提高了性能,缩短了计算佣金所需的时间消耗,但由于当时知识所限,这种相当于是傻瓜式的自动性能优化,也是存在一定的后遗症:
  1、未考虑索引命名规范,不利于后期索引修改维护。
  2、未考虑后面时间长了,会有索引碎片问题。因此当时未做定期重建索引的Sql作业。
  3、未考虑后面时间长了,会有统计信息不准确的可能。因此当时未做定期更新统计信息的Sql作业。
  希望过往经验能帮到各位程序猿朋友。