亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

SQLServer 2000 升級到 SQLServer 2008 性能之需要注意的地方之一

2024-08-31 00:57:40
字體:
來源:轉載
供稿:網友
測試sql:

復制代碼 代碼如下:


SET STATISTICS IO ON
SET STATISTICS TIME ON
SELECT COUNT(1)
FROM dbo.tbtext a
INNER LOOP JOIN dbo.tbtext b
ON a.id = b.id option (maxdop 1)
SET STATISTICS IO Off
SET STATISTICS TIME Off


表結構:

復制代碼 代碼如下:


CREATE TABLE [dbo].[tbtext](
[id] [int] IDENTITY(1,1) NOT NULL,
[VALUE] [int] NULL
) ON [PRIMARY]


單這句測試,看執行計劃根本看不出區別。
|--Compute Scalar(DEFINE:([Expr1006]=CONVERT_IMPLICIT(int,[Expr1009],0)))
|--Stream Aggregate(DEFINE:([Expr1009]=Count(*)))
|--Nested Loops(Inner Join, WHERE:([northwind].[dbo].[tbtext].[id] as [b].[id]=[northwind].[dbo].[tbtext].[id] as [a].[id]))
|--Table Scan(OBJECT:([northwind].[dbo].[tbtext] AS [a]))
|--Table Spool
|--Table Scan(OBJECT:([northwind].[dbo].[tbtext] AS [b]))
2008r2:

復制代碼 代碼如下:


/*
警告: 由于使用了本地聯接提示,聯接次序得以強制實施。
表 'tbtext'。掃描計數 1,邏輯讀取 46 次
(1 行受影響)
表 'Worktable'。掃描計數 1,邏輯讀取 290098 次,物理讀取 0 次,預讀 0 次,lob 邏輯讀取 0 次,lob 物理讀取 0 次,lob 預讀 0 次。
表 'tbtext'。掃描計數 2,邏輯讀取 262 次,物理讀取 0 次,預讀 0 次,lob 邏輯讀取 0 次,lob 物理讀取 0 次,lob 預讀 0 次。
(1 行受影響)
SQL Server 執行時間:
CPU 時間 = 32828 毫秒,占用時間 = 32846 毫秒。
SQL Server 執行時間:
CPU 時間 = 0 毫秒,占用時間 = 0 毫秒。
*/


2000sp4:

復制代碼 代碼如下:


/*
警告: 由于使用了局部聯接提示,所以聯接次序得以強制實施。
表 'tbtext'。掃描計數 1,邏輯讀 131 次,物理讀 0 次,預讀 0 次。
SQL Server 執行時間:
CPU 時間 = 0 毫秒,耗費時間 = 0 毫秒。
表 'Worktable'。掃描計數 9999,邏輯讀 180001 次,物理讀 0 次,預讀 0 次。
表 'tbtext'。掃描計數 2,邏輯讀 262 次,物理讀 0 次,預讀 138 次。
SQL Server 執行時間:
CPU 時間 = 17188 毫秒,耗費時間 = 17261 毫秒。
(1 行受影響)
SQL Server 執行時間:
CPU 時間 = 0 毫秒,耗費時間 = 0 毫秒。
*/


比較2000 和 2008的執行就能發現 2008 的cpu 時間明顯比 2000 高,2008 的worktable 邏輯讀取量,比2000的高,
這個有個worktable 的掃描技術,2000的是9999,2008的是1,這個讓人難免有的疑惑是什么情況,都是nest loop,worktable 掃描不應該是1才對。
性能差怎么大會不會是 worktable 搞的鬼呢?
那么就開始調節,過濾id 會有啥發現呢?

復制代碼 代碼如下:


SET STATISTICS IO ON
SET STATISTICS TIME ON
SELECT COUNT(1)
FROM dbo.tbtext a
INNER LOOP JOIN dbo.tbtext b
ON a.id = b.id
WHERE a.id <= 1000 option (maxdop 1)
SELECT COUNT(1)
FROM dbo.tbtext a
SET STATISTICS IO Off
SET STATISTICS TIME Off


2008r2:
SELECT COUNT(1) FROM dbo.tbtext a INNER LOOP JOIN dbo.tbtext b ON a.id = b.id WHERE a.id <= 1000 option (maxdop 1)
|--Compute Scalar(DEFINE:([Expr1006]=CONVERT_IMPLICIT(int,[Expr1009],0)))
|--Stream Aggregate(DEFINE:([Expr1009]=Count(*)))
|--Nested Loops(Inner Join, WHERE:([northwind].[dbo].[tbtext].[id] as [b].[id]=[northwind].[dbo].[tbtext].[id] as [a].[id]))
|--Table Scan(OBJECT:([northwind].[dbo].[tbtext] AS [a]), WHERE:([northwind].[dbo].[tbtext].[id] as [a].[id]<=(1000)))
|--Table Spool
|--Table Scan(OBJECT:([northwind].[dbo].[tbtext] AS [b]), WHERE:([northwind].[dbo].[tbtext].[id] as [b].[id]<=(1000)))

復制代碼 代碼如下:


表 'Worktable'。掃描計數 1,邏輯讀取 6006 次,物理讀取 0 次,預讀 0 次,lob 邏輯讀取 0 次,lob 物理讀取 0 次,lob 預讀 0 次。
表 'tbtext'。掃描計數 2,邏輯讀取 262 次,物理讀取 0 次,預讀 0 次,lob 邏輯讀取 0 次,lob 物理讀取 0 次,lob 預讀 0 次。


2000sp4:
|--Compute Scalar(DEFINE:([Expr1002]=Convert([Expr1006])))
|--Stream Aggregate(DEFINE:([Expr1006]=Count(*)))
|--Nested Loops(Inner Join, WHERE:([b].[id]=[a].[id]))
|--Table Scan(OBJECT:([Northwind].[dbo].[tbtext] AS [a]), WHERE:([a].[id]<=1000))
|--Table Spool
|--Table Scan(OBJECT:([Northwind].[dbo].[tbtext] AS [b]))

復制代碼 代碼如下:


表 'Worktable'。掃描計數 999,邏輯讀 27001 次,物理讀 0 次,預讀 0 次。
表 'tbtext'。掃描計數 2,邏輯讀 262 次,物理讀 0 次,預讀 0次。


進入 lazy spool的數據完全不一樣了,2008 只是進入了1000 條數據,但是2000 全都進去了。
在邏輯讀上面 2008 明顯低于 2000. cpu時間也明顯比2000少。
通過調節id 的值,2000 我推出了一個公式 邏輯讀= 10001+(17*n) ,
但是2008的算法十分奇怪,
當n < 386 時 邏輯讀=3+4(n-1)
當 386<=n<=770 邏輯讀= 1932+5(n-386)
2000的邏輯讀是線性增長,2008 是分段的線性增長,每個分段 f '(x) 都不一樣。
2008 的lazy spool適合選擇度高的,選擇度低的時候完全不行。
從2000到2008 不單單是多了sqlos和表面上的一些功能,很多執行計劃的操作符都被重寫了,像lazy spool 。
所以在升級到2008 之前,
各位朋友,是否都應該重寫一下sql 呢?單單優化 索引 已經解決不了根本問題了。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美国产中文字幕| 久久精品国产99国产精品澳门| 久久综合伊人77777尤物| 在线精品视频视频中文字幕| 欧美日韩国产一区在线| 国产在线播放91| 欧美高清性猛交| 66m—66摸成人免费视频| 亚洲成人激情图| 国产精品电影网| 国产精品免费久久久久久| 国产精品国产三级国产aⅴ浪潮| 久久人体大胆视频| 久久久天堂国产精品女人| 国产91精品不卡视频| 欧洲美女免费图片一区| 久久久噜噜噜久久中文字免| 国产91精品久久久| 久久久国产精品x99av| 欧美日韩国产色| 北条麻妃在线一区二区| 曰本色欧美视频在线| 国产精品美女网站| 色综合天天综合网国产成人网| 超碰日本道色综合久久综合| 亚洲欧美在线免费观看| 久久精品在线播放| 亚洲欧美日韩国产精品| 久久精品一区中文字幕| 欧美电影在线观看| 国产精品美女久久| 欧美一级成年大片在线观看| 欧美日韩另类在线| 久久久人成影片一区二区三区| 萌白酱国产一区二区| 国产精品h在线观看| 欧美一级视频在线观看| 成人免费视频网址| 91社影院在线观看| 国产成人aa精品一区在线播放| 在线电影中文日韩| 欧美国产日韩中文字幕在线| 国产aⅴ夜夜欢一区二区三区| 色综合久久精品亚洲国产| 91精品国产高清自在线| 18一19gay欧美视频网站| 亚洲国产美女精品久久久久∴| 成人激情视频在线| 亚洲第一福利在线观看| 日韩中文字幕免费视频| 三级精品视频久久久久| 亚洲国产精品电影在线观看| 97免费视频在线播放| 亚洲精品suv精品一区二区| 全色精品综合影院| 亚洲精品自拍偷拍| 欧美最近摘花xxxx摘花| 国产91亚洲精品| 亚洲大胆美女视频| 日本久久亚洲电影| 欧美日韩加勒比精品一区| 黄色成人在线免费| 九九九久久久久久| 中文字幕日韩欧美| 午夜精品福利视频| 永久555www成人免费| 日韩av在线一区| 91沈先生在线观看| 成人免费在线网址| 成人午夜在线影院| 亚洲人成网站999久久久综合| 国产日韩欧美在线观看| 色天天综合狠狠色| 亚洲第一免费网站| 日韩精品免费在线视频| 欧美国产精品va在线观看| 欧美另类极品videosbest最新版本| 69av成年福利视频| 久久国产精品99国产精| 精品调教chinesegay| 成人黄色影片在线| 亚洲精品aⅴ中文字幕乱码| 亚洲精品成人免费| 国产亚洲视频中文字幕视频| 日韩精品在线观看一区| 91精品久久久久久| 日韩中文字幕不卡视频| 亚洲免费高清视频| 精品高清美女精品国产区| 国产日本欧美一区二区三区在线| 久久国内精品一国内精品| 久久久精品国产亚洲| 96国产粉嫩美女| 久久久久www| 日韩精品视频免费| 国产精品免费一区| 日本亚洲欧美成人| 91福利视频在线观看| 国产精品欧美激情在线播放| 在线播放国产精品| 日韩av影院在线观看| 国产成人久久久精品一区| 大伊人狠狠躁夜夜躁av一区| 亚洲欧美国产视频| 国产精品视频一| 国产成人av在线播放| 中文字幕亚洲一区| 日韩高清不卡av| 国产精品高清在线| 国产精品va在线| 日韩精品视频免费在线观看| 日本19禁啪啪免费观看www| 亚洲自拍小视频免费观看| 亚洲国产精品久久| 欧美一级大片在线免费观看| 欧洲成人在线观看| 日韩高清中文字幕| 国产精品美女久久久免费| 国产精品网红福利| 中文字幕日韩高清| 亚洲欧美综合图区| 成人黄色av网| 美日韩精品免费观看视频| 国产一区视频在线| 欧美色videos| 亚洲自拍av在线| 国色天香2019中文字幕在线观看| 国产精品福利在线观看| 国产成人免费91av在线| 日韩欧美高清视频| 色综合男人天堂| 伊人伊成久久人综合网小说| 国产精品揄拍一区二区| 欧美成人精品一区二区| 欧美激情视频在线免费观看 欧美视频免费一| 欧美制服第一页| 久久久久99精品久久久久| 伊人久久久久久久久久久久久| 国产97在线视频| 久久免费视频在线| 久久久久久亚洲精品不卡| 欧美日韩另类在线| 精品美女国产在线| 欧美猛男性生活免费| 成人久久一区二区三区| 欧美成人激情图片网| 国产一区二区三区日韩欧美| 欧美三级欧美成人高清www| 国产婷婷97碰碰久久人人蜜臀| 国产成人精品免费久久久久| 91精品中国老女人| 亚洲欧美国产一本综合首页| 成人免费在线视频网站| 全球成人中文在线| 91精品久久久久久综合乱菊| 亚洲日本中文字幕免费在线不卡| 日韩a**中文字幕| 久久精品视频va| 亚洲在线一区二区| 日韩毛片在线观看| 国内精品一区二区三区四区| 夜夜嗨av一区二区三区四区| 隔壁老王国产在线精品| 午夜精品一区二区三区在线视频|