好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > SqlServer中tempdb的日志機制原理解析及示例分享

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

熱門標(biāo)簽:如何在地圖標(biāo)注自己店鋪 寧波人工外呼系統(tǒng)有效果嗎 廣州人工電銷機器人費用 400外呼系統(tǒng)合法 洛陽外呼系統(tǒng)平臺 電銷機器人被曝光 真人語音電銷機器人 怎樣把地圖標(biāo)注導(dǎo)入公司地址 地圖標(biāo)注一個圓圈怎么用

測試用例

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

Code

用戶數(shù)據(jù)庫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 (@i100000)
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 (@i100000)
begin
insert into #t1 select @i,'aa'
select @i=@i+1
end
select [extime]=DATEDIFF(S,@t,sysutcdatetime())

非臨時表在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 (@i100000)
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ān)的性能技術(shù)器的運行情況如(Log Bytes Flusged \sec 等)


                                                                              圖1-1

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

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

Tempdb的日志機制

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

Tempdb使用最小化日志

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

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

"快"的原因

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

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

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

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

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

我們通過簡單實例來看.

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每次重啟都會重新建立,我們無需重做日志,但運行過程中是可能需要回滾的,這也是tempdb日志存在的原因.

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

關(guān)于tempdb回滾.

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

Tempdb最佳實踐-日志

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

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

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

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

您可能感興趣的文章:
  • SQL Server誤區(qū)30日談 第12天 TempDB的文件數(shù)和需要和CPU數(shù)目保持一致
  • SqlServer數(shù)據(jù)庫提示 “tempdb” 的日志已滿 問題解決方案
  • 淺談tempdb在SqlServer系統(tǒng)中的重要作用
  • SqlServer提示“列前綴tempdb.無效: 未指定表名”問題解決方案
  • 更改SQL Server 2005數(shù)據(jù)庫中tempdb位置的方法
  • 談?wù)凾empdb對SQL Server性能優(yōu)化有何影響
  • 淺談SQL Server 2016里TempDb的進步

標(biāo)簽:石家莊 咸寧 煙臺 北海 東營 珠海 晉中 南昌

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SqlServer中tempdb的日志機制原理解析及示例分享》,本文關(guān)鍵詞  SqlServer,中,tempdb,的,日志,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SqlServer中tempdb的日志機制原理解析及示例分享》相關(guān)的同類信息!
  • 本頁收集關(guān)于SqlServer中tempdb的日志機制原理解析及示例分享的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: EEUSS影院WWW免费快飞| 校长室蹂躏白嫩的校花小说| 热带雨删减的视频在线观看| 摄影PANS私拍国模视频写真| 功夫熊猫42020版| 免费的短视频软件app下载| 色偷偷亚洲女性天堂| 小福利gif邪恶天堂78期| 亚洲欧美国产日韩制服bt| 1000部啪啪未满十八勿入第9集| 玖玖国产在线观看| 亚洲福利视频一区二区| 国产成人久久精品77777| 亚洲日本欧美中文幕| 国产精品原创永久在线观看| 黄色小短文| 99久久99久久久精品久久| 秋霞影院午夜伦A片欧美毛片| 国产AV一区二区在线观看| 接吻吃胸摸下面啪啪教程| 14女学生脱了内裤光着| 欧美激情视频在线免费观看| 女同性互吃奶乳免费视频| 五月婷婷激情视频| 红楼艳史小说全文阅读| jizzjizz日本护士久久高清| 国产黑色丝袜一区在线| xxxxxhd日本老师| 特级毛片在线观看| 彭丹被医生揉到高潮下不了床| A片????XXXX3D色情| 极品尤物在线| a级黄韩国免费播放| 久久精品国产亚洲AV果冻不片| 人妻熟女aⅴ一区二区三区汇编| 成人h动漫精品一区二区竹菊影视| 掀开奶罩边躁狠狠的躁动态图| 一边揉着胸一边舌吻| 国产激情视频在线| 医生掀开奶罩边躁边狠狠躁漫画| 色欲98久久综合国产精品三区 |