成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SQL Server數(shù)據(jù)庫分頁存儲過程優(yōu)化效率分析

數(shù)據(jù)庫 SQL Server
本文我們通過一個實例來分析SQL Server數(shù)據(jù)庫中分頁存儲過程的效率,從而找個更加高效的分頁方法,以便提高SQL查詢的效率,希望本次的介紹能夠?qū)δ兴鶐椭?/div>

SQL Server數(shù)據(jù)庫分頁存儲過程優(yōu)化效率分析是本文主要要介紹的內(nèi)容,接下來我們就開始介紹這一過程,SQL Server數(shù)據(jù)庫分頁存儲過程優(yōu)化效率分析先來對比兩段分頁SQL,假設(shè)條件:news表有15萬記錄,NewsTypeId=10有9萬記錄,當(dāng)前查詢NewsTypeID=10。那么,你會認(rèn)為哪個SQL效率會高呢?

代碼一:

 

  1. DECLARE @cc INT  
  2. SELECT NewsId,ROW_NUMBER() OVER(ORDER BY SortNum DESC)   
  3. AS RowIndex INTO #tb FROM news WITH(NOLOCK)   
  4. WHERE NewsTypeId=@NewsTypeId AND IsShow=1 
  5. SET @cc = @@ROWCOUNT  
  6. SELECT n.* FROM news AS n WITH(NOLOCK), #tb   
  7. As t WHERE t.RowIndex>@PageIndex*@PageSize   
  8. AND t.RowIndex<=(@PageIndex+1)*@PageSize  
  9. AND t.newsid=n.newsid  
  10. SELECT @cc  
  11. DROP TABLE #tb 

 

代碼二:

 

  1. DECLARE @cc INT  
  2. SELECT NewsId,ROW_NUMBER() OVER(ORDER BY SortNum DESC)  
  3. AS RowIndex INTO #tb FROM news WITH(NOLOCK)   
  4. WHERE NewsTypeId=@NewsTypeId AND IsShow=1 
  5. SET @cc = @@ROWCOUNT  
  6. SELECT NewsId INTO #tb2 FROM #tb As t   
  7. WHERE t.RowIndex>@PageIndex*@PageSize AND t.RowIndex<=(@PageIndex+1)*@PageSize  
  8. SELECT * FROM news WITH(NOLOCK)   
  9. WHERE NewsId IN (SELECT * FROM #tb2)  
  10. SELECT @cc  
  11. DROP TABLE #tb  
  12. DROP TABLE #tb2 

 

答案是代碼二遠(yuǎn)遠(yuǎn)高于代碼一。在代碼一中加粗代碼的操作會引起整表掃描,因為數(shù)據(jù)庫引擎在認(rèn)為WHERE表達(dá)式中滿足條件記錄大于一定閥值的時候,就不再去進(jìn)行查詢優(yōu)化,而直接使用表掃描。看執(zhí)行信息:

 

  1. 表 'news'。掃描計數(shù) 1,邏輯讀取 342 次,物理讀取 0 次,預(yù)讀 0 次,lob 邏輯讀取 0 次,lob 物理讀取 0 次,lob 預(yù)讀 0 次。  
  2. (98361 行受影響)  
  3. (1 行受影響)  
  4. (40 行受影響)  
  5. 表 '#tb________________________________________00000004C024'。  
  6. 掃描計數(shù) 1,邏輯讀取 257 次,物理讀取 0 次,預(yù)讀 0 次,lob 邏輯讀取 0 次,lob 物理讀取 0 次,lob 預(yù)讀 0 次。  
  7. 表 'news'。掃描計數(shù) 1,邏輯讀取 2805 次,物理讀取 0 次,預(yù)讀 235 次,lob 邏輯讀取 0 次,lob 物理讀取 0 次,lob 預(yù)讀 0 次。  
  8. (1 行受影響)  
  9. (1 行受影響)  
  10. 原本,我想的執(zhí)行計劃,加粗部分的代碼應(yīng)該是聚焦索引查找,這樣性能就提高很多。看代碼二:  
  11. 表 'news'。掃描計數(shù) 1,邏輯讀取 342 次,物理讀取 0 次,預(yù)讀 0 次,lob 邏輯讀取 0 次,lob 物理讀取 0 次,lob 預(yù)讀 0 次。  
  12. (98361 行受影響)  
  13. (1 行受影響)  
  14. 表 '#tb____________________________________00000004BEEF'。  
  15. 掃描計數(shù) 1,邏輯讀取 257 次,物理讀取 0 次,預(yù)讀 0 次,lob 邏輯讀取 0 次,lob 物理讀取 0 次,lob 預(yù)讀 0 次。  
  16. (40 行受影響)  
  17. (1 行受影響)  
  18. (40 行受影響)  
  19. 表 'news'。掃描計數(shù) 0,邏輯讀取 131 次,物理讀取 0 次,預(yù)讀 0 次,lob 邏輯讀取 0 次,lob 物理讀取 0 次,lob 預(yù)讀 0 次。  
  20. 表 '#tb2___________________________________00000004BEF0'。  
  21. 掃描計數(shù) 1,邏輯讀取 2 次,物理讀取 0 次,預(yù)讀 0 次,lob 邏輯讀取 0 次,lob 物理讀取 0 次,lob 預(yù)讀 0 次。  
  22. (1 行受影響)  
  23. (1 行受影響) 

 

很明顯,代碼二與代碼一中的IO操作數(shù)大大降低。且代碼一隨著@PageIndex越來越大,效率會越來越低;但代碼二的效率不會隨@PageIndex變化而改變。

以上就是SQL Server數(shù)據(jù)庫分頁存儲過程優(yōu)化效率分析的全部內(nèi)容,本文就介紹到這里了,希望本次的介紹能夠?qū)δ兴斋@!

【編輯推薦】

  1. 初學(xué)SQL Server數(shù)據(jù)庫的一些常用操作總結(jié)
  2. SQL Server數(shù)據(jù)庫創(chuàng)建數(shù)據(jù)倉庫已分區(qū)表詳解
  3. SQL Server與Access數(shù)據(jù)庫ASP代碼的比較詳解
  4. SQL Server數(shù)據(jù)庫中bit字段類型使用時的注意事項
  5. SQL Server數(shù)據(jù)庫timestamp數(shù)據(jù)類型相關(guān)知識介紹
責(zé)任編輯:趙鵬 來源: 博客園
相關(guān)推薦

2010-09-14 10:47:45

sql server存

2011-03-24 13:38:47

SQL Server 存儲分頁

2011-03-28 10:46:36

sql server存儲分頁

2011-07-13 16:19:54

存儲過程SQL Server數(shù)

2011-07-26 17:19:32

SQL Server數(shù)隨機(jī)抽取數(shù)據(jù)

2010-09-06 11:05:05

SQL SERVER語句

2011-07-28 14:31:47

SQL Server數(shù)存儲過程

2011-06-17 17:37:16

JavaSQL Server

2010-07-06 14:06:52

SQL Server存

2011-09-01 14:00:11

SQL Server 存儲過程顯示表結(jié)構(gòu)

2010-06-18 10:34:38

SQL Server

2010-06-30 14:36:49

SQL Server

2010-11-10 15:16:14

Sql Server分

2009-07-06 21:20:34

SQL Server數(shù)

2011-03-31 10:38:28

SQL Server編寫優(yōu)化

2010-07-01 13:42:58

SQL Server存

2011-07-19 15:18:46

存儲過程sql語句

2010-06-28 13:45:16

SQL Server

2011-08-15 15:14:54

SQL Server存儲過程異常處理

2009-03-11 15:40:20

點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 青青草视频网 | 99免费在线观看 | 国产成人精品在线 | 亚洲一区二区三区高清 | 色爱综合网 | 婷婷激情综合 | 日韩欧美在线一区 | 欧美a区 | 国产精品成人一区二区 | 精品视频在线免费观看 | 在线视频中文字幕 | 伊人网伊人 | 黄色片视频免费 | 欧美成人精品 | 国产精品视频网 | 国产精品久久 | 国产清纯白嫩初高生视频在线观看 | 国产 日韩 欧美 制服 另类 | 欧美日韩高清一区 | 婷婷久久综合 | 中文字幕亚洲欧美 | 欧美成人一区二区 | 欧美99久久精品乱码影视 | 真人女人一级毛片免费播放 | www.狠狠干| 天堂一区二区三区 | 日本在线播放一区二区 | 二区视频 | 中国人pornoxxx麻豆 | 欧美日韩精品一区二区三区四区 | 欧美一区二区三区 | 亚洲视频在线观看 | av在线免费观看网站 | 久久999| 精品在线观看入口 | av毛片 | 国产精品久久 | 国产精品美女 | 亚洲永久免费观看 | 免费视频一区二区 | 国产精品久久 |