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

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

SqlServer中tempdb的日志機制原理解析及示例分享

2024-08-31 01:02:27
字體:
來源:轉載
供稿:網友
tempdb為什么比其他數據庫快?估計95%以上的程序員們都一臉茫然.Tempdb作為Sqlserver的重要特征,一直以來大家對它可能即熟悉又陌生.熟悉是我們時時刻刻都在用,陌生可能是很少有人關注它的運行機制.這次我將通過實例給大家介紹下tempdb的日志機制.
 
 

測試用例

我們分別在用戶數據庫(testpage),tempdb中創建相似對象t1,#t1,并在tempdb中創建創建非臨時表,然后執行相應的insert腳本(用以產生日志),并記錄執行時間用以比較用以比較說明tempdb”快”

Code

用戶數據庫testpage

use testpagegocreate table t1(id int identity(1,1) not null,str1 char(8000))declare @t datetime2=sysutcdatetime()declare @i intset @i=1while (@i<100000)begininsert into t1 select @i,'aa'select @i=@i+1endselect [extime]=DATEDIFF(S,@t,sysutcdatetime())

tempdb

use tempdbgocreate table #t1(id int not null,str1 char(8000))declare @t datetime2=sysutcdatetime()declare @i intset @i=1while (@i<100000)begininsert into #t1 select @i,'aa'select @i=@i+1endselect [extime]=DATEDIFF(S,@t,sysutcdatetime())

非臨時表在tempdb中執行

use tempdbgocreate table t1(id int not null,str1 char(8000))declare @t datetime2=sysutcdatetime()declare @i intset @i=1while (@i<100000)begininsert into t1 select @i,'aa'select @i=@i+1endselect [extime]=DATEDIFF(S,@t,sysutcdatetime())

由圖1-1中我們可以看出,在普通表中執行一分鐘的腳本,tempdb只需執行22s.而普通表在tempdb中也只需27s均大大優于普通表中執行情況.

感興趣的朋友亦可在執行過程中觀察日志相關的性能技術器的運行情況如(Log Bytes Flusged /sec 等)

SqlServer中tempdb的日志機制原理解析及示例分享
                                                                              圖1-1

由此測試我們可以看出本文開始提到的”tempdb比其他數據庫快”.

實際并不是tempdb有什么魔法,而是tempdb的日志機制與其他數據庫大有不同.

Tempdb的日志機制

Tempdb Simple恢復模式(重啟后無需還原操作)

Tempdb使用最小化日志

Tempdb 不受系統CheckPoint影響(系統checkpoint不涉及tempdb,但人為tempdb中執行會落盤)

Tempdb 在刷入數據頁到磁盤前,日志無需落盤(事務提交日志無需落盤)

"快"的原因

可以看到系統檢查點自身會繞過tempdb,tempdb執行時無需日志先落盤.且會最小化日志記錄(關于此一個特性我會稍候陳述)這些都極大的緩解了磁盤IO瓶頸,使得tempdb相比其他DB會快很多.

注意:雖然系統checkpoint檢查點會繞過tempdb,但tempdb中人為執行checkpoint還是會起作用,大家只應測試環境中使用,正式環境中慎用!

在上面的實例中我們可以看到無論在表的類型是什么,在tempdb中速度都會有很大提升,但普通表的執行時間還是略長于臨時表,這是因為普通表的的日志記錄信息還是要略多于臨時表的.

關于tempdb最小化日志

在堆表(heap)中 insert,update操作的的更新信息日志無需記錄.

我們通過簡單實例來看.

USE [tempdb]GOcreate table #nclst(id int identity(1,1) primary key nonclustered,---heaptablestr1 char(8000));create table #clst(id int identity(1,1) primary key,------clusteredstr1 char(8000));checkpoint-----生產環境慎用!DBCC SHRINKFILE (N'templog' , 0, TRUNCATEONLY)GOinsert into #nclst(str1) select 'aa'select [Current LSN],Operation,CONTEXT,[Log Record Length] from fn_dblog(null,null) where AllocUnitId is not nullcheckpoint-----生產環境慎用!DBCC SHRINKFILE (N'templog' , 0, TRUNCATEONLY)GOinsert into #clst(str1) select 'aa'select [Current LSN],Operation,CONTEXT,[Log Record Length] from fn_dblog(null,null) where AllocUnitId is not null

由圖1-2中可以看出堆表中并未記錄Insert中的#ncls.str1的具體信息,而聚集表中則記錄相應信息

SqlServer中tempdb的日志機制原理解析及示例分享

                                                                               圖1-2

Tempdb為何需要日志

既然tempdb每次重啟都會重新建立,我們無需重做日志,但運行過程中是可能需要回滾的,這也是tempdb日志存在的原因.

Tempdb 不支持重做(Redo)但需支持回滾(rollback).

關于tempdb回滾.

Tempdb中如果日志文件中無足夠空間應用回滾則會引起整個實例就宕機!

Tempdb最佳實踐-日志

a 不要tempdb中checkpoint(消耗巨大引起系統性能下滑)

b 不要tempdb中開啟過長事務(無法截斷日志,造成日志過大,如回滾時無法回滾則宕機)

c 一般需要中間表匹配的過程在tempdb中創建進行(創建速度快,需視具體情況而定.)

d tempdb中使用堆表速度佳.(需視具體情況而定)


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品视频网址| 国产免费久久av| 久久91亚洲精品中文字幕| 欧美巨大黑人极品精男| 精品亚洲一区二区三区在线观看| 自拍偷拍免费精品| 欧美中文字幕在线播放| 久久99热这里只有精品国产| 久久国内精品一国内精品| 成人免费在线视频网站| 亚洲自拍偷拍色片视频| 欧美自拍大量在线观看| 国产精品99久久久久久人| 在线看日韩欧美| 亚洲色图综合久久| 亚洲欧洲高清在线| 午夜欧美大片免费观看| 亚洲免费高清视频| 综合欧美国产视频二区| 亚洲在线视频福利| 夜夜嗨av一区二区三区四区| 国产成人一区二| 九九热精品视频在线播放| 久久久极品av| 欧美国产亚洲精品久久久8v| 国产亚洲日本欧美韩国| 正在播放亚洲1区| 国产在线视频不卡| 国产精品视频公开费视频| 国产一区二区三区在线视频| 日韩成人在线电影网| 97国产精品人人爽人人做| 丰满岳妇乱一区二区三区| 精品国产欧美一区二区三区成人| 欧美激情亚洲一区| 国产精品视频永久免费播放| 中文字幕在线精品| 奇米一区二区三区四区久久| 国产精品夜间视频香蕉| 久久免费精品日本久久中文字幕| 日日骚av一区| 国产精品视频自拍| 九九精品在线观看| 精品久久久一区| 日韩在线观看你懂的| 国产一区二区三区免费视频| 欧美日韩国产精品一区二区不卡中文| 97精品免费视频| 国产精欧美一区二区三区| 国产精品一区二区3区| 欧美黑人性猛交| 国产精品福利观看| 成人午夜在线影院| 色噜噜国产精品视频一区二区| 国产原创欧美精品| 亚洲最大成人在线| 久久成人这里只有精品| 国产精品日韩久久久久| 欧美视频专区一二在线观看| 久久久免费高清电视剧观看| 国产一区二区欧美日韩| 亚洲电影在线看| 精品国产老师黑色丝袜高跟鞋| 国内精品久久久久影院优| 91丨九色丨国产在线| 久久久久久久久久久网站| 国产精品久久久久久久av电影| 97在线视频免费| 美女国内精品自产拍在线播放| 亚洲第一天堂无码专区| 中文字幕日韩精品有码视频| 欧美激情免费观看| 中日韩美女免费视频网站在线观看| 亚洲日韩中文字幕| 成人激情免费在线| 最近中文字幕mv在线一区二区三区四区| 91精品国产91久久久久久| 国产精品久久久久久久午夜| 亚洲综合在线中文字幕| 成人a视频在线观看| 欧美丰满少妇xxxx| 一区二区三区四区在线观看视频| 亚洲天堂男人天堂| 亚洲免费一在线| 98午夜经典影视| 欧美亚洲另类在线| 国产91热爆ts人妖在线| 国产精品欧美亚洲777777| 亚洲最新中文字幕| 国产精品欧美一区二区三区奶水| 国产一区二区精品丝袜| 国产欧美欧洲在线观看| 国产99视频精品免视看7| 欧美在线观看www| 日韩精品视频在线观看网址| 亚洲人成网在线播放| 伊人久久久久久久久久| 欧美在线观看一区二区三区| 欧美亚洲日本网站| 欧美成人激情视频免费观看| 久久999免费视频| 亚洲第一区中文99精品| 国产a∨精品一区二区三区不卡| 精品美女国产在线| 成人中文字幕+乱码+中文字幕| 啪一啪鲁一鲁2019在线视频| 91国产美女在线观看| 欧美性生活大片免费观看网址| 国产精品久久久久久亚洲影视| 97avcom| 国产精品久久9| 2023亚洲男人天堂| 亚洲人成电影在线观看天堂色| 色婷婷亚洲mv天堂mv在影片| 91精品久久久久久久久久入口| 亚洲第一页在线| 久久久久成人网| 亚洲国产精品99| 成人妇女淫片aaaa视频| 日韩经典中文字幕在线观看| 久久综合久久八八| 欧美极品少妇全裸体| 国产精品伦子伦免费视频| 欧美中文字幕视频| 久久99久久99精品中文字幕| 国内成人精品视频| 国产精品高潮呻吟久久av无限| 97超碰蝌蚪网人人做人人爽| 色综合天天狠天天透天天伊人| 亚洲乱码一区二区| 青青草原成人在线视频| 91超碰中文字幕久久精品| 91av在线免费观看视频| 最新91在线视频| 91av在线影院| 成人午夜在线观看| 日韩精品久久久久久久玫瑰园| 欧美日本亚洲视频| 国模极品一区二区三区| 国产精品美女午夜av| 国产成人一区二| 成人精品在线观看| 亚洲精品免费在线视频| 亚洲欧美日韩天堂一区二区| 欧美在线免费看| 中文字幕一精品亚洲无线一区| 久久精品中文字幕一区| 日韩在线视频观看| 成人免费淫片视频软件| 日韩视频亚洲视频| 97精品久久久| 欧美精品videossex性护士| 久久精品亚洲94久久精品| 97精品在线观看| 日韩精品免费综合视频在线播放| 亚洲人成电影网站色| 在线亚洲午夜片av大片| 亚洲精品xxxx| 日韩禁在线播放| 亚洲精品天天看| 亚洲一区中文字幕| 亚洲国产精品国自产拍av秋霞| 97国产精品人人爽人人做| 91在线观看免费高清完整版在线观看|