SqlServer中tempdb的日志機(jī)制原理解析及示例分享
測(cè)試用例
我們分別在用戶數(shù)據(jù)庫(kù)(testpage),tempdb中創(chuàng)建相似對(duì)象t1,#t1,并在tempdb中創(chuàng)建創(chuàng)建非臨時(shí)表,然后執(zhí)行相應(yīng)的insert腳本(用以產(chǎn)生日志),并記錄執(zhí)行時(shí)間用以比較用以比較說(shuō)明tempdb”快”
Code
用戶數(shù)據(jù)庫(kù)testpage
use testpage go create table t1 ( id int identity(1,1) not null, str1 char(8000) ) declare @t datetime2=sysutcdatetime() declare @i int set @i=1 while (@i<100000) begin insert into t1 select @i,'aa' select @i=@i+1 end select [extime]=DATEDIFF(S,@t,sysutcdatetime())
tempdb
use tempdb go create table #t1 ( id int not null, str1 char(8000) ) declare @t datetime2=sysutcdatetime() declare @i int set @i=1 while (@i<100000) begin insert into #t1 select @i,'aa' select @i=@i+1 end select [extime]=DATEDIFF(S,@t,sysutcdatetime())
非臨時(shí)表在tempdb中執(zhí)行
use tempdb go create table t1 ( id int not null, str1 char(8000) ) declare @t datetime2=sysutcdatetime() declare @i int set @i=1 while (@i<100000) begin insert into t1 select @i,'aa' select @i=@i+1 end select [extime]=DATEDIFF(S,@t,sysutcdatetime())
由圖1-1中我們可以看出,在普通表中執(zhí)行一分鐘的腳本,tempdb只需執(zhí)行22s.而普通表在tempdb中也只需27s均大大優(yōu)于普通表中執(zhí)行情況.
感興趣的朋友亦可在執(zhí)行過(guò)程中觀察日志相關(guān)的性能技術(shù)器的運(yùn)行情況如(Log Bytes Flusged \sec 等)
圖1-1
由此測(cè)試我們可以看出本文開(kāi)始提到的”tempdb比其他數(shù)據(jù)庫(kù)快”.
實(shí)際并不是tempdb有什么魔法,而是tempdb的日志機(jī)制與其他數(shù)據(jù)庫(kù)大有不同.
Tempdb的日志機(jī)制
Tempdb Simple恢復(fù)模式(重啟后無(wú)需還原操作)
Tempdb使用最小化日志
Tempdb 不受系統(tǒng)CheckPoint影響(系統(tǒng)checkpoint不涉及tempdb,但人為tempdb中執(zhí)行會(huì)落盤(pán))
Tempdb 在刷入數(shù)據(jù)頁(yè)到磁盤(pán)前,日志無(wú)需落盤(pán)(事務(wù)提交日志無(wú)需落盤(pán))
"快"的原因
可以看到系統(tǒng)檢查點(diǎn)自身會(huì)繞過(guò)tempdb,tempdb執(zhí)行時(shí)無(wú)需日志先落盤(pán).且會(huì)最小化日志記錄(關(guān)于此一個(gè)特性我會(huì)稍候陳述)這些都極大的緩解了磁盤(pán)IO瓶頸,使得tempdb相比其他DB會(huì)快很多.
注意:雖然系統(tǒng)checkpoint檢查點(diǎn)會(huì)繞過(guò)tempdb,但tempdb中人為執(zhí)行checkpoint還是會(huì)起作用,大家只應(yīng)測(cè)試環(huán)境中使用,正式環(huán)境中慎用!
在上面的實(shí)例中我們可以看到無(wú)論在表的類型是什么,在tempdb中速度都會(huì)有很大提升,但普通表的執(zhí)行時(shí)間還是略長(zhǎng)于臨時(shí)表,這是因?yàn)槠胀ū淼牡娜罩居涗浶畔⑦€是要略多于臨時(shí)表的.
關(guān)于tempdb最小化日志
在堆表(heap)中 insert,update操作的的更新信息日志無(wú)需記錄.
我們通過(guò)簡(jiǎn)單實(shí)例來(lái)看.
USE [tempdb] GO create table #nclst ( id int identity(1,1) primary key nonclustered,---heaptable str1 char(8000) ); create table #clst ( id int identity(1,1) primary key,------clustered str1 char(8000) ); checkpoint-----生產(chǎn)環(huán)境慎用! DBCC SHRINKFILE (N'templog' , 0, TRUNCATEONLY) GO insert into #nclst(str1) select 'aa' select [Current LSN],Operation,CONTEXT,[Log Record Length] from fn_dblog(null,null) where AllocUnitId is not null checkpoint-----生產(chǎn)環(huán)境慎用! DBCC SHRINKFILE (N'templog' , 0, TRUNCATEONLY) GO insert 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的具體信息,而聚集表中則記錄相應(yīng)信息
圖1-2
Tempdb為何需要日志
既然tempdb每次重啟都會(huì)重新建立,我們無(wú)需重做日志,但運(yùn)行過(guò)程中是可能需要回滾的,這也是tempdb日志存在的原因.
Tempdb 不支持重做(Redo)但需支持回滾(rollback).
關(guān)于tempdb回滾.
Tempdb中如果日志文件中無(wú)足夠空間應(yīng)用回滾則會(huì)引起整個(gè)實(shí)例就宕機(jī)!
Tempdb最佳實(shí)踐-日志
a 不要tempdb中checkpoint(消耗巨大引起系統(tǒng)性能下滑)
b 不要tempdb中開(kāi)啟過(guò)長(zhǎng)事務(wù)(無(wú)法截?cái)嗳罩?造成日志過(guò)大,如回滾時(shí)無(wú)法回滾則宕機(jī))
c 一般需要中間表匹配的過(guò)程在tempdb中創(chuàng)建進(jìn)行(創(chuàng)建速度快,需視具體情況而定.)
d tempdb中使用堆表速度佳.(需視具體情況而定)
- SQL Server誤區(qū)30日談 第12天 TempDB的文件數(shù)和需要和CPU數(shù)目保持一致
- SqlServer數(shù)據(jù)庫(kù)提示 “tempdb” 的日志已滿 問(wèn)題解決方案
- 淺談tempdb在SqlServer系統(tǒng)中的重要作用
- SqlServer提示“列前綴tempdb.無(wú)效: 未指定表名”問(wèn)題解決方案
- 更改SQL Server 2005數(shù)據(jù)庫(kù)中tempdb位置的方法
- 談?wù)凾empdb對(duì)SQL Server性能優(yōu)化有何影響
- 淺談SQL Server 2016里TempDb的進(jìn)步
相關(guān)文章
SQL Server 創(chuàng)建約束圖解(唯一 主鍵)
SQLServer中有五種約束,Primary Key約束、Foreign Key約束、Unique約束、Default約束和Check約束,今天使用SQL Server2008來(lái)演示下這幾種約束的創(chuàng)建和使用的方法2016-07-07sqlserver 動(dòng)態(tài)創(chuàng)建臨時(shí)表的語(yǔ)句分享
開(kāi)發(fā)業(yè)務(wù)需求,需要對(duì)一個(gè)表作數(shù)據(jù)分析,由于數(shù)據(jù)量較大,而且分析時(shí)字段會(huì)隨條件相應(yīng)變化而變化2012-01-01MSSQL MySQL 數(shù)據(jù)庫(kù)分頁(yè)(存儲(chǔ)過(guò)程)
有關(guān)分頁(yè) SQL 的資料很多,有的使用存儲(chǔ)過(guò)程,有的使用游標(biāo)。本人不喜歡使用游標(biāo),我覺(jué)得它耗資、效率低;使用存儲(chǔ)過(guò)程是個(gè)不錯(cuò)的選擇,因?yàn)榇鎯?chǔ)過(guò)程是經(jīng)過(guò)預(yù)編譯的,執(zhí)行效率高,也更靈活2012-01-01sql語(yǔ)句like多個(gè)條件的寫(xiě)法實(shí)例
這篇文章介紹了sql語(yǔ)句like多個(gè)條件的寫(xiě)法實(shí)例,有需要的朋友可以參考一下2013-10-10SQL Server 數(shù)據(jù)庫(kù)分離與附加 就這么簡(jiǎn)單!
這篇文章主要介紹了SQL Server 數(shù)據(jù)庫(kù)分離與附加,很簡(jiǎn)單的圖文教程,感興趣的小伙伴們可以參考一下2016-08-08在數(shù)據(jù)庫(kù)中自動(dòng)生成編號(hào)的實(shí)現(xiàn)方法分享
一直很討厭存儲(chǔ)過(guò)程,沒(méi)想到今天幫了我大忙啊,或許會(huì)因?yàn)榻裉熳屛衣矚g上存儲(chǔ)過(guò)程吧,不多說(shuō)了,切入正題2011-10-10Sql Server之?dāng)?shù)據(jù)類型詳解
本文詳細(xì)講解了Sql Server中的數(shù)據(jù)類型,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-02-02SQL Server Management Studio(SSMS)復(fù)制數(shù)據(jù)庫(kù)的方法
這篇文章主要為大家詳細(xì)介紹了如何利用SQL Server Management Studio復(fù)制數(shù)據(jù)庫(kù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03SQLServer Execpt和not in 性能區(qū)別
網(wǎng)上有很多 except 和 not in的返回結(jié)果區(qū)別這里就就提了2012-01-01vs code連接sql server數(shù)據(jù)庫(kù)步驟及遇到的問(wèn)題小結(jié)
這篇文章主要介紹了用vs code連接sql server數(shù)據(jù)庫(kù)步驟及遇到的問(wèn)題,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05