SQL编码中注意的性能问题
1、选择合适的数据类型
为列选择最小化的数据类型
假设一列中的文本长度不一,使用VARCHAR而不是CHAR
不存储Unicode不要使用NVARCHAR或者NCHAR
假设一行的长度不超过8000,使用VARCHAR而不是TEXT
对于仅存数字的列要使用数字类型而不要用字符类型
不要使用字符串类型存储日期数据。
2、慎重使用触发器
保持触发器内的代码最小化
可能的情况下尽量用其它更高效的技术替代触发器
尽量避免回滚触发器
3、仅仅返回须要的数据
横向来看,不要返回自己不须要的列,尽量不要使用select *
纵向来看,不要返回自己不须要的行,尽量使用where条件来过滤自己须要的内容
考虑使用TOP
考虑分页
对于聚合查询,能够用HAVING子句进一步限定返回的行。
4、尽量少做反复的工作
控制同一语句的多次运行,特别是一些基础数据的多次运行。
降低多次的数据转换,或许须要数据转换是设计的问题,可是降低次数是能够做到的。
合并对同一表同一条件的多次UPDATE,
UPDATE操作不要拆成DELETE操作+INSERT操作的形式。尽管功能同样。可是性能区别是非常大的。
不要写一些没有意义的查询。
插入大量数据时,尽量不要使用循环,能够使用CTE。假设要使用循环。也放到一个事务中;
5、注意暂时表使用方法
在复杂系统中,暂时表非常难避免。关于暂时表须要注意:
语句非常复杂,连接太多,能够考虑用暂时表分步完毕。
多次用到一个大表的同一部分数据,考虑用暂时表暂存数据。
须要综合多个表的数据,形成一个结果。能够考虑用暂时表分步汇总这多个表的数据。
其它情况下。应该控制暂时表和表变量的使用。
注意排序规则。
关于暂时表产生使用SELECT INTO和CREATE TABLE + INSERT INTO的选择.
6、避免使用游标
对于某些逐行的处理考虑放在client
考虑使用关联的子查询取代游标
必须使用游标时注意下面问题:
使用高效的游标类型(比如 forward-only)
使用server端游标时保持结果集尽量小。
游标使用结束时不能只CLOSE,还要DEALLOCATE。
7、 恰当使用连接
对于频繁连接的表用于连接的列须要有合适的索引
用于连接的列尽量使用同样的数据类型
避免将唯一值非常少的列用过连接列,否则会导致scan
假设有些查询须要对4个或很多其它的表进行连接,能够考虑低范化一些表
8、 其它须要注意的地方
问题发现的越早解决的成本越低,非常多性能问题能够在编码阶段就发现,为了提早发现性能问题,须要注意:
程序猿注意、关心各表的数据量。
编码过程和单元測试过程尽量用数据量较大的数据库測试,最好能用实际数据測试。
每一个SQL语句尽量简单
不要频繁更新有触发器的表的数据
注意数据库函数的限制以及其性能
SQL编码中注意的性能问题的更多相关文章
- 为什么SQL语句Where 1=1 and在SQL Server中不影响性能
		
最近一个朋友和我探讨关于Where 1=1 and这种形式的语句会不会影响性能.最后结论是不影响. 虽然结论正确,但对问题的认识却远远没有解决问题的根本.实际上在T-SQL语句的书写过 ...
 - SQL SERVER中一些常见性能问题的总结
		
1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免使用 left join 和 null 值判断.left join 比 in ...
 - sql中NVARCHAR(MAX) 性能和占空间分析   varchar(n),nvarchar(n) 长度性能及所占空间分析
		
varchar(n),nvarchar(n) 中的n怎么解释: nvarchar(n)最多能存n个字符,不区分中英文. varchar(n)最多能存n个字节,一个中文是两个字节. 所占空间: nvar ...
 - SQL Server中提前找到隐式转换提升性能的办法
		
http://www.cnblogs.com/shanksgao/p/4254942.html 高兄这篇文章很好的谈论了由于数据隐式转换造成执行计划不准确,从而造成了死锁.那如果在事情出现之前 ...
 - SQL Server中使用Check约束提升性能
		
在SQL Server中,SQL语句的执行是依赖查询优化器生成的执行计划,而执行计划的好坏直接关乎执行性能. 在查询优化器生成执行计划过程中,需要参考元数据来尽可能生成高效的执行计划, ...
 - SQL SERVER中用户定义标量函数(scalar user defined function)的性能问题
		
用户定义函数(UDF)分类 SQL SERVER中的用户定义函数(User Defined Functions 简称UDF)分为标量函数(Scalar-Valued Function)和表值函数(T ...
 - SQL Server中一个隐性的IO性能杀手-Forwarded record
		
简介 最近在一个客户那里注意到一个计数器很高(Forwarded Records/Sec),伴随着间歇性的磁盘等待队列的波动.本篇文章分享什么是forwarded record,并从原理上谈一 ...
 - SQL Server中多表连接时驱动顺序对性能的影响
		
本文出处:http://www.cnblogs.com/wy123/p/7106861.html (保留出处并非什么原创作品权利,本人拙作还远远达不到,仅仅是为了链接到原文,因为后续对可能存在的一些错 ...
 - 编码中常用的SQL语法
		
蓝色标注的都是比较常见的SQL ====================== 开发中常见的SQL: left join , right join 防止丢弃数据 inner join CASE WHNE ...
 
随机推荐
- php常量,提前定义常量,魔术常量及基本数据类型
			
常量 定义: 形式一 // define("PI",常量值); define("PI",3.14); define("school",&qu ...
 - 图像滤镜艺术---保留细节的磨皮之C#程序实现
			
上一篇博文"保留细节的磨皮滤镜之PS实现"一文中.我简介了本人自己总结的一种非常easy的磨皮滤镜,这个滤镜在磨光皮肤的同一时候,会保留非常不错的细节,今天,我将介绍使用C#程序实 ...
 - 火狐浏览器中加入httprequest的方法
			
今天弄了非常久就才装好. 以下的样例是以 window为样例的,mac的也是这样, 下载好火狐之后点击右上角的菜单 想到httprequest是个插件,就点击附加组件 搜索出来之后找到httprequ ...
 - 解决ORA-02395:超出I/O使用的调用限制问题
			
ORACLE的PROFILE文件是限制数据库用户使用的资源的一种手段.如:控制session或sql能使用的CPU.控制用户的password管理策略等. 数据库创建后,系统则存在名为DEFAULT的 ...
 - java位运算笔记
			
位运算: ~(非)-->二进制数进行0和1的互换 样例: public class Test { public static void main(String[] args) { System. ...
 - tflearn中一些CNN RNN的例子
			
lstm.py # -*- coding: utf-8 -*- """ Simple example using LSTM recurrent neural networ ...
 - Windows远程桌面和360
			
Windows的远程桌面输错了一次密码, 然后就怎么都连接不上了, 查了半天发现 傻缺360会默认屏蔽Windows的远程桌面和数据库连接..... 大家没事都卸载了360吧
 - POJ 2771 最大独立集 匈牙利算法
			
(为什么最大独立集的背景都是严打搞对象的( _ _)ノ|壁) 思路:匈牙利算法 没什么可说的-- // by SiriusRen #include <cstdio> #include &l ...
 - Oracle中的数据字典技术及常用数据字典总结
			
一.Oracle数据字典 数据字典是Oracle存放有关数据库信息的地方,其用途是用来描述数据的.比如一个表的创建者信息,创建时间信息,所属表空间信息,用户访问权限信息等.当用户在对数据库中的数据进行 ...
 - Tomcat配置自签名https
			
从JDK中找到keytool.exe,随便复制到一个方便的目录,在命令行中进入这个目录. 第一步:为服务器生成证书 tomcat.keystore,命令中如果是IP方式访问用-ext SAN=ip:1 ...