问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

关于T-SQL的问题

发布网友 发布时间:2022-05-05 12:24

我来回答

3个回答

懂视网 时间:2022-05-05 16:46

有关T-SQL的10个好习惯 1. 在生产环境中不要出现Select * 这一点我想大家已经是比较熟知了,这样的错误相信会犯的人不会太多。但我这里还是要说一下。 不使用Select *的原因主要不是坊间所流传的将*解析成具体的列需要产生消耗,这点消耗在我看来完全可以忽

有关T-SQL的10个好习惯

1. 在生产环境中不要出现Select *

  这一点我想大家已经是比较熟知了,这样的错误相信会犯的人不会太多。但我这里还是要说一下。

  不使用Select *的原因主要不是坊间所流传的将*解析成具体的列需要产生消耗,这点消耗在我看来完全可以忽略不计。更主要的原因来自以下两点:

  • 扩展方面的问题
  • 造成额外的书签查找或是由查找变为扫描
  •   扩展方面的问题是当表中添加一个列时,Select *会把这一列也囊括进去,从而造成上面的第二种问题。

      而额外的IO这点显而易见,当查找不需要的列时自然会产生不必要的IO,下面我们通过一个非常简单的例子来比较这两种差别,如图1所示。

    1

    图1.*带来的不必要的IO

      2. 声明变量时指定长度

      这一点有时候会被人疏忽,因为对于T-SQL来说,如果对于变量不指定长度,则默认的长度会是1。考虑下面这个例子,如图2所示。

    2

    图2.不指定变量长度有可能导致丢失数据

      3. 使用合适的数据类型

      合适的数据类型首先是从性能角度考虑,关于这一点,我写过一篇文章详细的介绍过,有兴趣可以阅读:对于表列数据类型选择的一点思考,这里我就不再细说了

      不要使用字符串类型存储日期数据,这一点也需要强调一些,有时候你可能需要定义自己的日期格式,但这样做非常不好,不仅是性能上不好,并且内置的日期时间函数也不能用了。

      4. 使用Schema前缀来选择表

      解析对象的时候需要更多的步骤,而指定Schema.Table这种方式就避免了这种无谓的解析。

      不仅如此,如果不指定Schema容易造成混淆,有时会报错。

      还有一点是,Schema使用的混乱有可能导致更多的执行计划缓存,换句话说,就是同样一份执行计划被多次缓存,让我们来看图3的例子。

    3

    图3.不同的schema选择不同导致同样的查询被多次缓存

      5. 命名规范很重要

      推荐使用实体对象+操作这种方式,比如Customer_Update这种方式。在一个大型一点的数据库会存在很多存储过程,不同的命名方式使得找到需要的存储过程变得很不方便。因此有可能造成另一种问题,就是重复创建存储过程,比如上面这个例子,有可能命名规范不统一的情况下又创建了一个叫UpdateCustomer的存储过程。

      6. 插入大量数据时,尽量不要使用循环,可以使用CTE,如果要使用循环,也放到一个事务中

      这点其实显而易见。SQL Server是隐式事务提交的,所以对于每一个循环中的INSERT,都会作为一个事务提交。这种效率可想而知,服务器空间,但如果将1000条语句放到一个事务中提交,效率无疑会提升不少。

      打个比方,去银行存款,是一次存1000效率高,还是存10次100?

      7. where条件之后尽量减少使用函数或数据类型转换

      换句话说,WHERE条件之后尽量可以使用可以嗅探参数的方式,比如说尽量少用变量,虚拟主机,尽量少用函数,下面我们通过一个简单的例子来看这之间的差别。如图4所示。

    4

    图4.在Where中使用不可嗅探的参数导致的索引查找

      对于另外一些情况来说,尽量不要让参数进行类型转换,再看一个简单的例子,我们可以看出在Where中使用隐式转换代价巨大。如图5所示。

    5

    图5.隐式转换带来的性能问题

      8. 不要使用旧的连接方式,比如(from x,y,美国服务器,z)

      可能导致效率底下的笛卡尔积,当你看到下面这个图标时,说明查询分析器无法根据统计信息估计表中的数据结构,所以无法使用Loop join, merge Join和Hash Join中的一种,而是使用效率地下的笛卡尔积。

      所以,尽量使用Inner join的方式替代from x, y, z这种方式。

      9. 使用游标时,加上只读只进选项

      首先,我的观点是:游标是邪恶的,尽量少用。但是如果一定要用的话,请记住,默认设置游标是可进可退的,如果你仅仅设置了

    declare c cursor for

    热心网友 时间:2022-05-05 13:54

    WITH CHECK ADD CONSTRAINT [CK_Table_1] CHECK (([ys]='男' OR [ys]='女'))

    热心网友 时间:2022-05-05 15:12

    使用约束啊,帮助里查一下,笨啊你
    声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
    硅胶与液态硅胶手机壳的区别 什么样的过敏会传染 过敏的原理是什么?为什么有的人过敏,有的人不过敏?谢谢! 过敏为什么会痒 评审报告需要注意什么 财政评审流程及注意事项 高效项目评审的6大注意事项 银行双录 什么意思 什么是银行双录 在异地哪些可公证 学java有什么用?是不是只有继续学jsp才有用? 只学Java一门,出去找工作?可有人要?!.. 现在学习java对我们到底有没有用啊 只学Java真的够吗 苹果电脑鼠标怎么关闭休眠模式 MacBooK AIr触摸鼠标怎么关?在线等! 没有VISA卡号怎么注册itunes账号 没有visa卡 麻烦帮忙注册苹果itunes帐号 工行学生信用卡(visa),可以用来注册苹果账号并付款吗?谢谢~ 需visa信用卡卡号 我注册一iTunes账号啊!! 跪求 pyhrsh126@126.com 如何注册Apple ID?VISA卡是什么卡??招商银行信用卡不行么??? itunes 账号怎么注册啊?我新买的苹果4 为什么信用卡注册一定要visa啊?怎么跳过这一栏啊? Mac10.15.3屏幕出现这个鼠标自选功能如何关闭? 各位高手帮帮忙好吗,我刚买了一个ipad2,需要注册,后面需要一个visa的信用卡号才能注册 浦发visa卡 怎么注册apple id 我注册APPLE ID,需一个VISA信用卡卡号和安全码,我的邮箱:dlcxzz@163.com 能帮忙注册个免费版吗? 各位高手帮帮忙好吗,我刚买了一个ipad,需要注册,后面需要一个visa的信用卡号才能注册 请问现在在苹果的iTunes上注册帐户必须要Visa或Mastercard的信用卡账号才行吗? 有什么jdg管规格? 地下城金秋称号在哪里买 华硕artone笔记本怎么样? 华硕笔记本V5200怎么样? 华硕vivobook笔记本电脑怎么样?可以买吗? 张会轩的介绍 张会轩的人物经历 长春工业大学资产经营有限责任公司怎么样? 长春工业大学的办学条件 社区家政府的基本思路有哪些? 社区家庭互助式教育如何落地 梦幻西游藏宝阁买了个号,社区家不知道多少号,找不到怎么办 社区家里养猫养狗经营允许吗? 户口本上左上角写着社区家庭户口是什么意思? 社区服务的宗旨是什么? 社区家庭病床名词解释 考上了社区家里人非要喊去考辅警,哪个是更好点 社区家庭户会影响孩子高考吗 社区家园网能给居民带来什么好处 社区家园用英语用英语怎么翻译的? 老公去世要开具社区家庭成员关系怎么写 全世界流通货币有多少种?列举最常用的10种?