欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

SqlServer中tempdb的日志機(jī)制原理是什么

這篇文章將為大家詳細(xì)講解有關(guān)SqlServer中tempdb的日志機(jī)制原理是什么,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了廬山免費(fèi)建站歡迎大家使用!

測(cè)試用例

我們分別在用戶數(shù)據(jù)庫(testpage),tempdb中創(chuàng)建相似對(duì)象t1,#t1,并在tempdb中創(chuàng)建創(chuàng)建非臨時(shí)表,然后執(zhí)行相應(yīng)的insert腳本(用以產(chǎn)生日志),并記錄執(zhí)行時(shí)間用以比較用以比較說明tempdb”快”

Code

用戶數(shù)據(jù)庫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())

非臨時(shí)表在tempdb中執(zhí)行

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中我們可以看出,在普通表中執(zhí)行一分鐘的腳本,tempdb只需執(zhí)行22s.而普通表在tempdb中也只需27s均大大優(yōu)于普通表中執(zhí)行情況.

感興趣的朋友亦可在執(zhí)行過程中觀察日志相關(guān)的性能技術(shù)器的運(yùn)行情況如(Log Bytes Flusged \sec 等)

圖1-1

由此測(cè)試我們可以看出本文開始提到的”tempdb比其他數(shù)據(jù)庫快”.

實(shí)際并不是tempdb有什么魔法,而是tempdb的日志機(jī)制與其他數(shù)據(jù)庫大有不同.

Tempdb的日志機(jī)制

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

Tempdb使用最小化日志

Tempdb 不受系統(tǒng)CheckPoint影響(系統(tǒng)checkpoint不涉及tempdb,但人為tempdb中執(zhí)行會(huì)落盤)

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

"快"的原因

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

注意:雖然系統(tǒng)checkpoint檢查點(diǎn)會(huì)繞過tempdb,但tempdb中人為執(zhí)行checkpoint還是會(huì)起作用,大家只應(yīng)測(cè)試環(huán)境中使用,正式環(huán)境中慎用!

在上面的實(shí)例中我們可以看到無論在表的類型是什么,在tempdb中速度都會(huì)有很大提升,但普通表的執(zhí)行時(shí)間還是略長(zhǎng)于臨時(shí)表,這是因?yàn)槠胀ū淼牡娜罩居涗浶畔⑦€是要略多于臨時(shí)表的.

關(guān)于tempdb最小化日志

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

我們通過簡(jiǎn)單實(shí)例來看.

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-----生產(chǎn)環(huán)境慎用!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-----生產(chǎn)環(huán)境慎用!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的具體信息,而聚集表中則記錄相應(yīng)信息

圖1-2

Tempdb為何需要日志

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

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

關(guān)于tempdb回滾.

Tempdb中如果日志文件中無足夠空間應(yīng)用回滾則會(huì)引起整個(gè)實(shí)例就宕機(jī)!

Tempdb最佳實(shí)踐-日志

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

b 不要tempdb中開啟過長(zhǎng)事務(wù)(無法截?cái)嗳罩?造成日志過大,如回滾時(shí)無法回滾則宕機(jī))

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

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

關(guān)于SqlServer中tempdb的日志機(jī)制原理是什么就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

本文名稱:SqlServer中tempdb的日志機(jī)制原理是什么
URL地址:http://aaarwkj.com/article0/jpoeoo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序、網(wǎng)站策劃、商城網(wǎng)站、虛擬主機(jī)建站公司、自適應(yīng)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運(yùn)營(yíng)
91精品国产综合久久麻豆| 日韩国产在线一区二区| 日韩亚洲av在线免费观看| 国产黄色看三级91大片| 欧美欧成人一区二区三区a∨| 美国真人性做爰视频免费| sedoge在线播放免费有码| 久久视频在线播放视频| 韩国三级伦理中文字幕| 国产日韩综合精品一区| 在线国产偷拍自拍视频| 亚洲精品一区二区99| 亚洲av乱码一区二区三四五六七| 香蕉夜夜草草久久亚洲香蕉| 国产精品一区二区麻豆本子| 午夜性生活视频免费看| 青青久久精品国产亚洲av| 高清中文一区二区三区| 欧美日韩亚洲精品久久| 欧美三级欧美一级视频看| 欧美日韩一区二区三区666| 日韩黄色大片免费在线观看| 亚洲中文字幕伦理在线| 日本人妻系列在线播放| 夜色一区二区av人片| 亚洲精品??一区二区| 精品国产自在现线拍手机| 日韩av不卡免费播放| 白浆视频在线免费观看| 人妻口爆视频一区二区三区| av二区不卡国产精品| 在线日韩欧美一区二区三区| 最新国产情侣夫妻激情| 91熟女激情五月综合| 蜜桃av在线观看一区二区| 嫩草网站国产精品一区二| 久久蜜臀av一区三区| 天堂av新版在线观看| 国产大学生情侣在线视频| 99久久夜国产精品| 男人天堂手机视频在线|