ImageVerifierCode 换一换
格式:DOCX , 页数:10 ,大小:195.50KB ,
资源ID:23048043      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/23048043.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(有关TSQL的10个好习惯.docx)为本站会员(b****1)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

有关TSQL的10个好习惯.docx

1、有关TSQL的10个好习惯有关T-SQL的10个好习惯 1.在生产环境中不要出现Select * 这一点我想大家已经是比较熟知了,这样的错误相信会犯的人不会太多。但我这里还是要说一下。 不使用Select *的原因主要不是坊间所流传的将*解析成具体的列需要产生消耗,这点消耗在我看来完全可以忽略不计。更主要的原因来自以下两点: 扩展方面的问题 造成额外的书签查找或是由查找变为扫描 扩展方面的问题是当表中添加一个列时,Select *会把这一列也囊括进去,从而造成上面的第二种问题。 而额外的IO这点显而易见,当查找不需要的列时自然会产生不必要的IO,下面我们通过一个非常简单的例子来比较这两种差别,

2、如图1所示。 图1.*带来的不必要的IO2.声明变量时指定长度 这一点有时候会被人疏忽,因为对于T-SQL来说,如果对于变量不指定长度,则默认的长度会是1.考虑下面这个例子,如图2所示。 图2.不指定变量长度有可能导致丢失数据3.使用合适的数据类型 合适的数据类型首先是从性能角度考虑,关于这一点,我写过一篇文章详细的介绍过,有兴趣可以阅读:对于表列数据类型选择的一点思考,这里我就不再细说了 不要使用字符串类型存储日期数据,这一点也需要强调一些,有时候你可能需要定义自己的日期格式,但这样做非常不好,不仅是性能上不好,并且内置的日期时间函数也不能用了。4.使用Schema前缀来选择表 解析对象的时

3、候需要更多的步骤,而指定Schema.Table这种方式就避免了这种无谓的解析。 不仅如此,如果不指定Schema容易造成混淆,有时会报错。 还有一点是,Schema使用的混乱有可能导致更多的执行计划缓存,换句话说,就是同样一份执行计划被多次缓存,让我们来看图3的例子。 图3.不同的schema选择不同导致同样的查询被多次缓存5.命名规范很重要 推荐使用实体对象+操作这种方式,比如Customer_Update这种方式。在一个大型一点的数据库会存在很多存储过程,不同的命名方式使得找到需要的存储过程变得很不方便。因此有可能造成另一种问题,就是重复创建存储过程,比如上面这个例子,有可能命名规范不统

4、一的情况下又创建了一个叫UpdateCustomer的存储过程。6.插入大量数据时,尽量不要使用循环,可以使用CTE,如果要使用循环,也放到一个事务中 这点其实显而易见。SQL Server是隐式事务提交的,所以对于每一个循环中的INSERT,都会作为一个事务提交。这种效率可想而知,但如果将1000条语句放到一个事务中提交,效率无疑会提升不少。 打个比方,去银行存款,是一次存1000效率高,还是存10次100?下面,根据吉日的要求,补个例子,见代码1.CREATE TABLE dbo.TestInsert( Number INT PRIMARY KEY);-循环插入,不给力,我的笔记本45秒D

5、ECLARE index INT;SET index = 1;WHILE index = 100000BEGIN INSERT dbo.TestInsert(Number) VALUES( index); SET index = index + 1;END-放到一个事务中循环,略好,但也不是最好,我的笔记本1秒BEGIN TRANDECLARE index INT;SET index = 1;WHILE index 这里我再补充一点,我说得是“可能”导致,因为上面这个查询可能作为中间结果或是子查询,当你忘写了where条件时,会是笛卡尔积。你在最终结果中再用where过滤,可能得到的结果一模一

6、样,但是中间的过程却大不相同 所以,尽量使用Inner join的方式替代from x,y,z这种方式。9.使用游标时,加上只读只进选项 首先,我的观点是:游标是邪恶的,尽量少用。但是如果一定要用的话,请记住,默认设置游标是可进可退的,如果你仅仅设置了declare c cursor for 这样的形式,那么这种游标要慢于下面这种方式。 declare c cursor local static read_only forward_only for 所以,在游标只读只进的情况下,加上上面代码所示的选项。10.有关Order一些要注意的事情 首先,要注意,不要使用Order by+数字的形式,比如图6这种。 图6.Order By序号 当表结构或者Select之后的列变化时,这种方式会引起麻烦,所以老老实实写上列名。 还有一种情况是,对于带有子查询和CTE的查询,子查询有序并不代表整个查询有序,除非显式指定了Order By,让我们来看图7。 图7.虽然在CTE中中有序,但显式指定Order By,则不能保证结果的顺序

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1