职业IT人-IT人生活圈

 找回密码
 成为会员
搜索
查看: 1271|回复: 0

看看如何编写高效的数据库代码(转载)

[复制链接]
cayean 发表于 2006-11-23 21:18 | 显示全部楼层 |阅读模式
优化要点和编写任何程序代码一样,构建T-SQL查询的方法也不止一种,以下是提升性能的一些指导方针。

WHERE语句

您应当适用WHERE语句来控制返回的数据行的数量,如果不使用WHERE语句,SQL Server会执行对整个表格进行扫描并返回所有的行(如果确实需要这样做,您可以不必适用WHERE语句,但是所有其他的情况下都要使用WHERE语句。)

您应当使用WHERE语句来支持HAVING语句,当您将GROUP BY和HAVING语句一起使用的时候,GROUP BY会将数据行分为不同的组并聚合它们的值,然后HAVING语句会剔除不需要的组。在有些情况下,您可以编写只包含WHERE和GROUP BY的语句而不需要HAVING语句。

数据列

使用星号(*)可以在查询中很容易地返回所有数据列的值,您应当只获取必需的数据行。结果集合中的数据列越少,数据量就会越少,这样网络流量的负担就会减小。性能的提升依赖于数据列的数量,所以对数据列进行限定是一种良好的习惯。

避免指针

SQL Server的指针功能可以在扫描结果中进行循环,但是这一功能的代价就是性能。指针功能对于每夜的服务器任务来讲是不错的,但是要在您的应用软件的代码/过程中避免使用指针。最好使用选择语句来返回需要的值并在客户端处理这些数据。
您需要登录后才可以回帖 登录 | 成为会员

本版积分规则

QQ|手机版|小黑屋|网站帮助|职业IT人-IT人生活圈 ( 粤ICP备12053935号-1 )|网站地图
本站文章版权归原发布者及原出处所有。内容为作者个人观点,并不代表本站赞同其观点和对其真实性负责,本站只提供参考并不构成任何投资及应用建议。本站是信息平台,网站上部分文章为转载,并不用于任何商业目的,我们已经尽可能的对作者和来源进行了通告,但是能力有限或疏忽造成漏登,请及时联系我们,我们将根据著作权人的要求立即更正或者删除有关内容。

GMT+8, 2024-5-14 11:39 , Processed in 0.111987 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表