承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601
当前位置:首页  >  互联网圈  >  总结SQL履行进展优化方法

总结SQL履行进展优化方法

管理员 2023-06-26 08:28:45 互联网圈 9 ℃ 0 评论 4839字 收藏

在本文中,小编将与大家重点探讨SQL履行进展优化的方法。

聚集索引扫描

SELECT * FROM C_SY_Ownedstorm

聚集索引扫描比表扫描快

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

表扫描

SELECT * FROM #temp

表扫描:产生于堆表,并且没有可用的索引时,会产生表扫描,表示全部表扫描一次。

测试SQL

CREATE TABLE t1(c1 INT, c2 VARCHAR (8000));

GO

DECLARE @a INT;

SELECT @a = 1;

WHILE (@a <= 5000)

BEGIN

INSERT INTO t1 VALUES (@a, replicate(‘a’, 5000))

SELECT @a = @a + 1

END

GO
SELECT count(1) FROM t1

group by c1

哈希匹配:

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

有缺失或不正确的索引

缺少where字句

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

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

聚集索引查找:

CREATE UNIQUE CLUSTERED INDEX _Id

ON t1(c1)

select * from t1

where c1=3

排序:

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

select * from t1
order by desc

循环嵌套

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

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

合并连接

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

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

本篇文章到此结束,如果您有相关技术方面疑问可以联系我们技术人员远程解决,感谢大家支持本站!

文章来源:丸子建站

文章标题:总结SQL履行进展优化方法

https://www.wanzijz.com/view/59297.html

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信