SQL语句的几个好习惯
SQL语句的几个好习惯
SQL语句的几个好习惯一. 声明变量时指定长度
这一点有时候会被人疏忽,因为对于T-SQL来说,如果对于变量不指定长度,则默认的长度会是1。考虑下面这个例子,如图
二. 使用合适的数据类型
合适的数据类型首先是从性能角度考虑,关于这一点,我写过一篇文章详细的介绍过,有兴趣可以阅读:对于表列数据类型选择的一点思考,这里我就不再细说了
不要使用字符串类型存储日期数据,这一点也需要强调一些,有时候你可能需要定义自己的日期格式,但这样做非常不好,不仅是性能上不好,并且内置的日期时间函数也不能用了。
三. 使用Schema前缀来选择表
解析对象的时候需要更多的步骤,而指定Schema.Table这种方式就避免了这种无谓的解析。
不仅如此,如果不指定Schema容易造成混淆,有时会报错。
还有一点是,Schema使用的混乱有可能导致更多的执行计划缓存,换句话说,就是同样一份执行计划被多次缓存,让我们来看图
四. 命名规范很重要
推荐使用实体对象+操作这种方式,比如Customer_Update这种方式。在一个大型一点的数据库会存在很多存储过程,不同的命名方式使得找到需要的存储过程变得很不方便。因此有可能造成另一种问题,就是重复创建存储过程,比如上面这个例子,有可能命名规范不统一的情况下又创建了一个叫UpdateCustomer的存储过程。
五. 插入大量数据时,尽量不要使用循环,可以使用CTE,如果要使用循环,也放到一个事务中
这点其实显而易见。SQL Server是隐式事务提交的,所以对于每一个循环中的INSERT,都会作为一个事务提交。这种效率可想而知,但如果将1000条语句放到一个事务中提交,效率无疑会提升不少。
打个比方,去银行存款,是一次存1000效率高,还是存10次100?
六. where条件之后尽量减少使用函数或数据类型转换
换句话说,WHERE条件之后尽量可以使用可以嗅探参数的方式,比如说尽量少用变量,尽量少用函数,下面我们通过一个简单的例子来看这之间的差别。如图
对于另外一些情况来说,尽量不要让参数进行类型转换,再看一个简单的例子,我们可以看出在Where中使用隐式转换代价巨大。如图5所示。
七. 不要使用旧的连接方式,比如(from x,y,z)
可能导致效率底下的笛卡尔积,当你看到下面这个图标时,说明查询分析器无法根据统计信息估计表中的数据结构,所以无法使用Loop join, merge Join和Hash Join中的一种,而是使用效率地下的笛卡尔积。
所以,尽量使用Inner join的方式替代from x, y, z这种方式。
八. 使用游标时,加上只读只进选项
首先,我的观点是:游标是邪恶的,尽量少用。但是如果一定要用的话,请记住,默认设置游标是可进可退的,如果你仅仅设置了
declare c cursor for
这样的形式,那么这种游标要慢于下面这种方式。
declare c cursor local static read_only forward_only for…
所以,在游标只读只进的情况下,加上上面代码所示的选项。
九. 有关Order一些要注意的事情
首先,要注意,不要使用Order by+数字的形式,比如图6这种。
当表结构或者Select之后的列变化时,这种方式会引起麻烦,所以老老实实写上列名。
还有一种情况是,对于带有子查询和CTE的查询,子查询有序并不代表整个查询有序,除非显式指定了Order By,让我们来看图7。
- 软件测试常用mysql语句(MySQL压力测试工具Mysqlslap的使用)
- mysql常用的sql语句大全(mysql建表常用的sql语句汇总)
- 用mysql语句写python学生管理系统(Python基于mysql实现学生管理系统)
- mysql语句性能分析(聊聊MySQL的COUNT*的性能)
- 如何查看sql语句执行时间
- sql数据库查询优化(数据库SQL语句优化总结收藏)
- thinkphp框架切换数据库(ThinkPHP3.2.3框架实现执行原生SQL语句的方法示例)
- django数据库查询条件(djang常用查询SQL语句的使用代码)
- laravel查询限制输出设置(laravel 获取某个查询的查询SQL语句方法)
- activiti需要sql语句吗(Activiti-Explorer使用sql server数据库实现方法)
- django怎么设置数据库(django配置连接数据库及原生sql语句的使用方法)
- dedecms时间代码(Dedecms中常用数据调用的sql语句汇总)
- laravel mysql 操作方式(Laravel使用原生sql语句并调用的方法)
- php提供哪些函数来避免sql的注入(PHP与SQL语句写一句话木马总结)
- sqlserver分页查询sql语句(sql server实现分页的方法实例分析)
- sql语句计算年龄(sql通过日期判断年龄函数的示例代码)
- 三杨之一 南杨 杨溥 安贞履节,酿醴调羹,宰相之气(三杨之一南杨杨溥)
- 今天会下雨吗(今天会下雨吗小说)
- 追连续剧,品古今联4 明代三杨,联妙诗佳(追连续剧品古今联4)
- 三杨 共辅四朝帝王,构建明帝国内阁行政圈(三杨共辅四朝帝王)
- 红色文化进国企(红色文化进国企)
- 车友的选择| 轮毂该如何选(车友的选择轮毂该如何选)
热门推荐
- 百度网速买的五分钟加速在哪里(为何用了百度云加速 服务器负载还很大)
- vue界面自动生成(Vue中实现3D标签云的详细代码)
- CentOS 7下安装配置proftpd搭建ftp服务器的详细教程(CentOS 7下安装配置proftpd搭建ftp服务器的详细教程)
- 如何让mysql强制设置复杂的密码
- pythondict排序原理(Python标准库使用OrderedDict类的实例讲解)
- navicat15.0.28注册码(Navicat for MySQL 11注册码激活码汇总)
- centos7rabbitmq怎么装(如何在centos上使用yum安装rabbitmq-server)
- python中tkinter模块窗口操作(详解python tkinter教程-事件绑定)
- 如何挑选云服务器(高质量的美国云服务器选择方法有哪些?)
- 用php调用函数的换行(php中关于换行的实例写法)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9