SQL性能学习汇总 00
1.在一条语句中不要重复使用相同的函数
2.尽可能在存储过程中使用临时变量和临时表
如 IF (Object_ID('tempdb..#T') IS NOT NULL) DROP TABLE #T
SELECT … INTO #T FROM…
DROP TABLE #T ;
3.当用SELECT INTO时,它会锁住系统表(SYSOBJECTS,SYSINDEXES等等),
阻碍其他连接的存取。所以在创建临时表时应该用显示申明语句,
即不在事务内使用SELECT INTO语句。
select into #T .......
Begin tran
update #T .......
end tran
4.存储过程中涉及更改数据时一定要使用try catch 事务 回滚等
5.SELECT子句中避免使用'*' 尽可能的写出需要查询的字段名
6.条件中尽量少用否定类型的运算符,条件中尽量少用
'<>', '!=''NOT IN', 'NOT EXISTS','NOT LIKE'等否定类型的运算符,
因为它们不走索引全是表扫描 效率高低比较EXISTS > IN > NOT EXISTS > NOT IN,
所以可用EXISTS代替IN的使用, NOT EXISTS或(OUTER JOIN)代替NOT IN的使用。
7.在WHERE条件中IN后的值排序为先繁后少,减少判断次数
8.避免在索引列上使用IS NULL 和 IS NOT NULL。NULL条件将使该索引无法作用。
9.尽可能不在条件中使用函数
10.用'>=','<='替代'>','<'
示例(不推荐)
SELECT EmpNO
FROM EMP
WHERE DeptNO > 3;
示例(推荐)
SELECT EmpNO
FROM EMP
WHERE DeptNO >= 4;
两者区别在于,前者DBMS将直接跳到Dept等于4的记录而后者将首先定位
到DeptNO = 3的记录再向前扫描到第一个Dept大于3的记录
11.UNION代替OR的使用
12.TOP + 数值 替代 TOP + 百分比 的使用
13.尽量使用精准查询
在LIKE语句中,若能确定使用LIKE'a%'则不用LIKE'%a'或LIKE'%a%'
因为前者能用上索引,而后两者则不能。
且LIKE'%a%'查询时的耗时和字段值总长度成正比,
所以用VARCHAR比用CHAR类型较高效。
如果能精准查询则坚决不能采用模糊查询。
14.条件允许时UNION ALL替代UNION的使用
15.没有必要时不用DISTINCT和ORDER BY
DISTINCT和ORDER BY这些动作可以改在客户端执行。
它们增加了额外的开销。这同UNION和UNION ALL一样的道理
16.使用批处理更新语句,一次更新多条记录比分多次更新而每次更新一条语句快。
SQL性能学习汇总 00的更多相关文章
- SQL性能优化汇总
		
SQL效率低下也是导致性能差的一个非常重要的原因,可以通过查看执行计划看SQL慢在哪里,一般情况,SQL效率低下原因主要有: 类别 子类 表达式或描述 原因 索引 未建索引 无 产生全表扫描 未利 ...
 - ORACLE SQL性能优化汇总
		
ORACLE SQL语句共享 Oracle SQL语句具备共享特性,为了不让ORACLE数据库重复解析相同的简单单表SQL语句,ORACLE在SGA系统共享区域内SBP共享池内存放的SQL语句将被所有 ...
 - ORACLE数据库学习之SQL性能优化详解
		
 Oracle sql 性能优化调整 ...
 - Mysql高级操作学习笔记:索引结构、树的区别、索引优缺点、创建索引原则(我们对哪种数据创建索引)、索引分类、Sql性能分析、索引使用、索引失效、索引设计原则
		
Mysql高级操作 索引概述: 索引是高效获取数据的数据结构 索引结构: B+Tree() Hash(不支持范围查询,精准匹配效率极高) 树的区别: 二叉树:可能产生不平衡,顺序数据可能会出现链表结构 ...
 - sqlt 之 分析 DB upgrade 导致SQL 性能下降 的方法 xplore
		
https://blog.csdn.net/lukeUnique/article/details/79331779 https://mauro-pagano.com/2014/10/27/when-t ...
 - Oracle 数据库SQL性能查看
		
作为一个开发/测试人员,或多或少都得和数据库打交道,而对数据库的操作归根到底都是SQL语句,所有操作到最后都是操作数据,那么对sql性能的掌控又成了我们工作中一件非常重要的工作.下面简单介绍下一些查看 ...
 - SQL语句学习手册实例版
		
SQL语句学习手册实例版 表操作 例1 对于表的教学管理数据库中的表 STUDENTS ,可以定义如下: CREATE TABLE STUDENTS (SNO NUMERIC (6, ...
 - 一个有趣的SQL Server 层级汇总数据问题
		
看SQL Server大V宋大侠的博客文章,发现了一个有趣的sql server层级汇总数据问题. 具体的问题如下: parent_id emp_id emp_nam ...
 - SQL索引学习-聚集索引
		
这篇接着我们的索引学习系列,这次主要来分享一些有关聚集索引的问题.上一篇SQL索引学习-索引结构主要是从一些基础概念上给大家分享了我的理解,没有实例,有朋友就提到了聚集索引的问题,这里列出来一下: 其 ...
 
随机推荐
- BZOJ1572 工作安排 USACO2009
			
描述 Description Farmer John 有太多的工作要做啊!!!!!!!!为了让农场高效运转,他必须靠他的工作赚钱,每项工作花一个单位时间.他的工作日从0时刻开始,有100000 ...
 - nginx 499 状态码优化
			
在grafana界面中发现不少499的状态码,在网上了解到出现499的原因大体都是说服务端处理时间过长,客户端主动关闭了连接. 既然原因可能是服务端处理时间太长了,看一下upstream_resp ...
 - 网站访问量大 怎样优化mysql数据库
			
MySQL优化的一些建议,单机MySQL的优化我分为三个部分,一是服务器物理硬件的优化,二是 MySQL安装时的编译优化,三是自身配置文件my.cnf的优化:如果单机的优化也解决不了你的数据库的压力的 ...
 - [Unity3D]导入模型并且设置相应的属性
			
将资源拷贝到Assets中并设置 首先确保法线贴图的属性如下: 设置基本贴图和法线贴图 因为要发布到移动端,设置shader属性: 为了设置更好的反光效果,添加cubemap: 添加新的Materia ...
 - yaf学习资料
			
yaf学习资料 文档 鸟哥的官方文档 Yaf框架结合PHPUnit的集成测试 php yaf框架扩展实践六--单元测试.计划任务.第三方库等 php yaf框架扩展实践一--配置篇 yaf实战例子 y ...
 - iframe的自适应高度
			
<iframe src="index.html" id="iframepage" name="iframepage" frameBor ...
 - 在Heroku部署时,无法加载 css,js,图片资源解决办法
			
解决方案: 首先查看Gemfile, 确保group :production do 里添加了 gem "rails_12factor", '0.0.2' 然后在本地执行 rails ...
 - LOL 控制技能的解释
			
压制:硬控的一种,是指A在释放压制型技能的时候B无法进行任何动作,可以被 水银腰带 和 坩埚盖 解除(原来可以完全解掉,现在貌似只是能动,伤害还在继续,比如蚱蜢的R中,用水银解掉之后可以立即跑开,但是 ...
 - MySQL Where 条件
			
WHERE 条件 有时候操作数据库时,只操作一些有条件限制的数据,这时可以在SQL语句中添加WHERE子句来规定数据操作的条件. 语法: SELECT column,… FROM tb_name WH ...
 - java基础知识(一)数据类型(下)
			
前面介绍了java的8种基本数据类型,包括boolean, byte, char, short, int, long, float, double.同时,java也提供了这些类型的封装类,分别为Bo ...