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

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

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

  • 扩展方面的问题

  • 造成额外的书签查找或是由查找变为扫描

  扩展方面的问题是当表中添加一个列时,Select *会把这一列也囊括进去,从而造成上面的第二种问题。

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

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

  2. 声明变量时指定长度

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

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

  3. 使用合适的数据类型

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

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

  4. 使用Schema前缀来选择表

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

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

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

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

  5. 命名规范很重要

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

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

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

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

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

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

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

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

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

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

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

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

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

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

declare c cursorfor 

  这样的形式,那么这种游标要慢于下面这种方式。

declare c cursorlocal static read_only forward_onlyfor… 

  所以,在游标只读只进的情况下,加上上面代码所示的选项。

  10. 有关Order一些要注意的事情

  首先,要注意,不要使用Order by+数字的形式,比如图6这种。

图6.Order By序号

  当表结构或者Select之后的列变化时,这种方式会引起麻烦,所以老老实实写上列名。

  还有一种情况是,对于带有子查询和CTE的查询,子查询有序并不代表整个查询有序,除非显式指定了Order By,让我们来看图7。

图7. 虽然在CTE中中有序,但显式指定Order By,则不能保证结果的顺序

【基础】有关T-SQL的10个好习惯相关推荐

  1. mysql 立方根函数_PostgreSQL基础知识之SQL操作符实践指南

    前言 操作符是数据库具有的运算特性,对文本字符和一些标签字符的处理,使用操作符可以简化SQL代码,同时也可以节省开发时间和提高开发效率. 比较操作符 在PostgreSQL中,所有的数据类型都可以使用 ...

  2. [SQL基础教程]1-4 SQL 表的创建

    [SQL基础教程]1-4 SQL 表的创建 创建数据库 语法 CREATE DATABASE <数据库名称> // example CREATE DATABASE shop; 创建表 语法 ...

  3. Analysis Services基础知识——深入SQL Server 2008

    Analysis Services基础知识 --深入SQL Server 2008 这一节中,我们将介绍Analysis Services的体系结构,这个体系结构在SQLServer2005中建立,并 ...

  4. Red Gate系列之一 SQL Compare 10.4.8.87 Edition 数据库比较工具 完全破解+使用教程

    原文:Red Gate系列之一 SQL Compare 10.4.8.87 Edition 数据库比较工具 完全破解+使用教程 Red Gate系列之一 SQL Compare 10.4.8.87 E ...

  5. Sams Teach Yourself SQL in 10 Minutes, Third Edition

    版权声明:原创作品,允许转载,转载时请务必以超链接形式标明文章原始出版.作者信息和本声明.否则将追究法律责任. http://blog.csdn.net/topmvp - topmvp Sams Te ...

  6. SharePoint 2016 企业项目管理应用(二,基础安装配置SQL Server 2014 安装)

    SharePoint 2016 企业项目管理应用(二,基础安装配置SQL Server 2014 安装) 关于服务器操作系统的安装配置,这里不做说明,安装完成后执行加域操作. 1.首先修改数据库服务器 ...

  7. Android基础入门教程——2.4.10 Spinner(列表选项框)的基本使用

    Android基础入门教程--2.4.10 Spinner(列表选项框)的基本使用 标签(空格分隔): Android基础入门教程 本节引言: 本来本节是想给大家介绍一个Gallery(画廊)的一个控 ...

  8. Java语言程序设计 基础篇 原书第10版 ,梁勇著,百度云链接及密码

    一本好书,对java小白来说是一本非常不错的书.第一次分享,请大家多多指教, Java语言程序设计 基础篇 原书第10版 ,梁勇著 链接:https://pan.baidu.com/s/1-MN_AS ...

  9. 让我郁闷的不行的SQL Anywhere 10

    今天, 一个非常郁闷的一天. 因为遇到了让我郁闷的SQL Anywhere 10. 因为我一不小心安装了一下这个软件, 同时也一不小心卸载了这个软件, 也正是同时, 它也一不小心的导致我的VS 200 ...

最新文章

  1. 「机器学习速成」训练神经网络:反向传播、梯度爆炸消失Dropout
  2. python的seaborn下载_Python可视化 | Seaborn包—heatmap()
  3. Response.Redirect ,Server.Transfer ,Server.Execute, 的区别(比较)
  4. 170525、解决maven隐式依赖包版本问题
  5. python3 venv 虚拟环境使用
  6. linux ospf 命令,OSPF单区域配置 - linuxprobe2020的个人空间 - OSCHINA - 中文开源技术交流社区...
  7. MySQL入门 (七) : 储存引擎与资料型态
  8. 蒸汽朋克简单图形免扣PNG素材,让设计艺术变得简单
  9. Json API接口数据生成
  10. linux视频截取命令(ffmpeg)
  11. 快速注册认证小程序,三分钟学会免300元认证企业小程序
  12. 静态IP、动态IP、ADSL拨号和DNS这几者你分得清吗?
  13. js 拉勾网效果_js仿拉勾网首页穿墙广告效果
  14. 软件工程导论第九到十二章章节复习总结附思维导图
  15. Node.js基础(二)-- 模块化、npm与包
  16. (解决)org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)问题的办法
  17. iOS 如何先由子视图处理子手势后再交由父类
  18. C语言之实用调试技巧
  19. 泽塔云CEO查乾:2019年超融合进入成熟市场,GPU云带来千亿级市场
  20. 【RESTful】REST 与 RESTful 理解与实践

热门文章

  1. c语言基础知识_结构体访问,共同体,枚举类型
  2. 智能音箱 之 平台方案简介
  3. 时钟切换处理(Verilog)
  4. 【tensorflow】——创建tensor的方法
  5. python需要背的英语单词怎么写_学Python必须背的42个常见单词,看看你都会吗?...
  6. pb 如何导出csv_Firefox火狐浏览器将提供导出密码至本地的功能
  7. oracle18c卸载方法,在debian 10上安装和卸载oracle数据库快捷版18c第4版
  8. linux nfs 配置_centos7 NFS 配置
  9. csi python 摄像头 树莓派_树莓派之摄像头和人脸识别
  10. Fragment管理工具类