很多年前,笔者那时刚从广东技术师范学院(现为广东技术师范大学,以前为广东民族学院)的计算机科学学院计算机科学与技术(师范)专业(广东专插本,本科插本生,跨专业)毕业不久,还没怎么了解索引和执行计划这些知识,而遇到财务某系统计算佣金特别慢的性能问题。那时通过百度,有目的性,又有点盲目地查找相关数据库性能优化的技巧,其中有一个技巧就用上了,效果也还可以,分享给大家:
Step 1:使用Sql Server自带的性能工具【Profiler】,抓取系统运行的SQL语句并保存为跟踪文件。
Step 2:使用Sql Server自带的性能工具【数据库引擎优化顾问】,对Step 1抓取的跟踪文件进行自动分析,会自动给出增加索引和统计信息之类的建议,直接应用到数据库就可以。
现在回过头来看,当时这样操作确实大大提高了性能,缩短了计算佣金所需的时间消耗,但由于当时知识所限,这种相当于是傻瓜式的自动性能优化,也是存在一定的后遗症:
1、未考虑索引命名规范,不利于后期索引修改维护。
2、未考虑后面时间长了,会有索引碎片问题。因此当时未做定期重建索引的Sql作业。
3、未考虑后面时间长了,会有统计信息不准确的可能。因此当时未做定期更新统计信息的Sql作业。
希望过往经验能帮到各位程序猿朋友。
sql server数据库建立大量测试数据 测试sql server效率
转载本文章为转载内容,我们尊重原作者对文章享有的著作权。如有内容错误或侵权问题,欢迎原作者联系我们进行内容更正或删除文章。
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
sql server 数据库日志还原
角色是一个权限的集合,只要将用户加入到角色成员(给用户分配一个角色),就可以给这个用户分配这个角色所具有的全部权限。角色的出现极大的简化了权限的管理。
服务器角色 数据库角色 用户定义数据库角色 架构