SQL 执行进展优化方法总结

数据库 SQL Server
谈到优化就必然要涉及索引,就像要讲锁必然要说事务一样,建议读者先了解一下索引。在本文中,笔者将与大家重点探讨SQL执行进展优化的方法。

聚集索引扫描

 

  1. SELECT *  FROM C_SY_Ownedstorm 

聚集索引扫描比表扫描快

聚集索引扫描:发生于聚集表,也相当于全表扫描操作,但在针对聚集列的条件等操作时,效率会较好。

表扫描

 

  1. SELECT *   FROM #temp 

表扫描:发生于堆表,并且没有可用的索引时,会发生表扫描,表示整个表扫描一次。

SQL 执行进展优化

 

 

测试SQL

 

  1. CREATE TABLE t1(c1 INT, c2 VARCHAR (8000)); 
  2.  
  3.  GO 
  4.  
  5.   DECLARE @a INT
  6.  
  7.   SELECT @a = 1; 
  8.  
  9.  WHILE (@a <= 5000) 
  10.  
  11.  BEGIN              
  12.  
  13.      INSERT INTO t1 VALUES (@a, replicate('a', 5000)) 
  14.  
  15.      SELECT @a = @a + 1 
  16.  
  17.  END 
  18.  
  19.  GO 

 

  1. SELECT count(1) FROM t1 
  2.  
  3. group by  c1 

哈希匹配:

哈希匹配的作用就是把它右侧的两个表中行数比较少的那个经过哈希算法形成一个哈希表,然后再有另一个数据行数比较大的表来之前形成的哈希表中匹配查找数据,大体上就是这个么流程。但是哈希匹配操作的出现一定要提高我们的警惕,当哈希匹配右侧的两个表中的数据有一个比另一个明显的少的时候,哈希匹配的效率会比较高,反之就会影响效率。出现哈希匹配大概有这么几个情况:

有缺失或者不正确的索引

缺少where字句

在where子句中有对列的类型转换或者数据操作,这样就不能使用索引了

虽说哈希匹配在某些情况下效率会比较高,但是这并不意味着没有更好的来提高这个查询的效率,比如添加适当的索引或者通过where语句来减少数据量等方法。换句话说,当出现哈希匹配这个操作的时候,我们要引起注意,看看是否还有别的方法来提高查询效率,如果没有的话,或许哈希匹配就是***的选择了。

 

 

SQL 执行进展优化

聚集索引查找:

 

  1. CREATE UNIQUE CLUSTERED INDEX _Id 
  2.  
  3. ON t1(c1) 
  4.  
  5. select  * from  t1 
  6.  
  7. where c1=3 

 

 

SQL 执行进展优化

排序:

排序是消耗性能的,sql server中排序是在数据找出来以后在进行排序的。

 

  1. select  * from  t1 
  2.  order by desc 

 

 

循环嵌套

对于使用简单内连接的小数据量表,嵌套循环是***策略。最适合两个表的记录数差别非常大,并且在连接的列上都有索引的情况。嵌套循环连接所需的I/O和比较都是最少的。

嵌套循环在外表(往往是小数据量的表)中每次循环一个记录,然后在内表中查找所匹配的记录并输出。有很多关于嵌套循环策略的名字。例如,对整个表或索引进行查询,称为Naive(无知的)嵌套循环连接。使用正常索引或临时索引时,被称为索引嵌套循环连接或临时索引嵌套循环连接。

 

 

SQL 执行进展优化

合并连接

合并连接也是在读的同时对两个存储输入的一行进行比较。在每个步骤中,比较每个输入的下一行。如果两行是相同,输出一个连接后的行并继续。如果行是不同的,舍弃两个输入行中较少的那个并继续。因为输入是存储,连接舍弃的任何行必须比两个输入中任何剩下的行要小,因此可以永不连接。合并连接不需要对两个输入中的每一行扫描。只要到了两个输入中的某一个的末尾,合并连接就会停止扫描。

嵌套循环连接总的消耗和在输入表中行的乘积成比例,不同于嵌套循环连接,合并连接的表最多读一次,总的消耗和输入行数的总数成正比例,因此何必连接对于大量的输入是较好的选择。

SQL 执行进展优化

博文出处:http://www.cnblogs.com/linfangshuhellowored/p/4430293.html

责任编辑:Ophira 来源: cnblogs
相关推荐

2016-12-08 15:47:54

sql优化数据

2011-08-18 09:19:19

SQL Server的SQL查询优化

2012-09-11 15:43:32

HBase

2011-04-06 11:16:47

SQL Server数查询优化

2011-04-06 11:34:52

SQL Server数查询优化

2011-06-20 14:22:58

外链

2011-08-18 15:03:47

SQL Server多优化方案

2020-01-16 18:30:07

技术SQL优化

2015-07-02 11:17:30

MySQLSlave延迟优化

2021-07-16 23:01:03

SQL索引性能

2021-07-26 18:23:23

SQL策略优化

2014-01-24 09:58:45

fuse文件系统

2017-11-09 17:35:21

数据库OracleSQL优化

2009-03-11 15:40:20

2010-09-25 16:21:41

SQL语句

2011-03-28 17:12:36

sql server数优化

2017-01-23 08:40:33

动态符号代码覆盖测试

2010-03-31 15:03:54

Oracle执行

2010-07-22 11:09:33

SQL Server内

2014-07-18 09:33:53

数据库数据库优化
点赞
收藏

51CTO技术栈公众号