国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

SQL2008中通過DBCCOPENTRAN和會話查詢事務

來源:懂視網 責編:小采 時間:2020-11-09 09:25:43
文檔

SQL2008中通過DBCCOPENTRAN和會話查詢事務

SQL2008中通過DBCCOPENTRAN和會話查詢事務:無論是有意無意,如果事務在數據庫中保持打開,則它會阻塞其他進程對修改后的數據進行操作。 同樣,對事務日志進行備份也只會截斷不活動事務的那部分事務日志,所以打開的事務會導致日志變多(甚至達到物理限制),直到事務被提交或回滾。 要找到最早的活動
推薦度:
導讀SQL2008中通過DBCCOPENTRAN和會話查詢事務:無論是有意無意,如果事務在數據庫中保持打開,則它會阻塞其他進程對修改后的數據進行操作。 同樣,對事務日志進行備份也只會截斷不活動事務的那部分事務日志,所以打開的事務會導致日志變多(甚至達到物理限制),直到事務被提交或回滾。 要找到最早的活動

無論是有意無意,如果事務在數據庫中保持打開,則它會阻塞其他進程對修改后的數據進行操作。

同樣,對事務日志進行備份也只會截斷不活動事務的那部分事務日志,所以打開的事務會導致日志變多(甚至達到物理限制),直到事務被提交或回滾。

要找到最早的活動事務,可以使用DBCC OPENTRAN命令。詳細用法見MSDN:

給出一個示例:
代碼如下:


CREATE TABLE T_Product(PKID int, PName Nvarchar(50));
GO
BEGIN TRAN
INSERT INTO T_Product VALUES (101, '嫦娥四號');
GO
DBCC OPENTRAN;
ROLLBACK TRAN;
GO
DROP TABLE T_Product;
GO

執行結果:
代碼如下:

/*
(1 row(s) affected)
數據庫 'Testdb' 的事務信息。

最早的活動事務:
SPID (服務器進程 ID): 54
UID (用戶 ID): -1
名稱 : user_transaction
LSN : (295:6687:1)
開始時間 : 12 24 2010 2:50:15:607PM
SID : 0x0105000000000005150000007fe010d31cba1ab1566ac5dff4010000
DBCC 執行完畢。如果 DBCC

輸出了錯誤信息,請與系統管理員聯系。
*/

結果顯示了最早活動日志的相關信息,包括服務器進程ID、用戶ID、和事務的開始時間。關鍵是SPID和Start Time。
擁有這些信息后,可以使用動態管理視圖(DMV)來檢驗正在執行的T-SQL,以及在必要時關閉這個過程
DBCC OPENTRAN對于孤立連接(在數據庫中是打開的,但與應用程序或客戶端已經斷開的連接)是非常有用的,并能幫助我們找出遺漏了COMMIT或ROLLBACK的事務。該命令也返回在指定數據庫內存在最早的活動事務和最早的分布式和非分布式復制事務。如果沒有活動事務,則顯示信息性消息,而不返回會話級數據。

我們看一個實例:
代碼如下:


SET Transaction isolation level serializable
BEGIN TRAN

select * from T_Product

Insert into T_Product
select 'OATest' union all
select 'OAPlay'

這是一個未提交的事務,在另一個查詢窗口執行如下:
代碼如下:


select session_id,transaction_id,is_user_transaction,is_local
from sys.dm_tran_session_transactions
where is_user_transaction=1

執行結果:
代碼如下:

/*返回結果
session_id transaction_id is_user_transaction is_local
54 489743 1 1
*/

返回會話ID后,可以通過sys.dm_exec_connections和sys.dm_exec_sql_text來挖掘最近執行的查詢的詳細信息。
代碼如下:

select s.text from sys.dm_exec_connections c
cross apply sys.dm_exec_sql_text(c.most_recent_sql_Handle) s
where session_id=54

這個查詢返回最后執行的語句。也可以使用sys.dm_exec_requests。
因為也從sys.dm_tran_session_transactions的第一個查詢中得知事務ID,所以可以使用sys.dm_tran_active_transactions來了解更多事務本身的內容
代碼如下:

select transaction_begin_time,
case transaction_type
when 1 then 'Read/Write transaction'
when 2 then 'Read-Only transaction'
when 3 then 'System transaction'
when 4 then 'Distributed transaction'
end tran_Type,
case transaction_state
when 0 then 'not been comoletely initaialiaed yet'
when 1 then 'initaialiaed but ha notstarted'
when 2 then 'active'
when 3 then 'ended (read-only transaction)'
when 4 then 'commit initiated for distributed transaction'
when 5 then 'transaction prepared and waiting resolution'
when 6 then 'commited'
when 7 then 'being rolled back'
when 0 then 'been rolled back'
end transaction_state
from
sys.dm_tran_active_transactions
where transaction_ID=455520

代碼如下:

/*結果:
transaction_begin_time tran_Type transaction_state
2010-12-24 14:05:29.170 Read/Write transaction active
*/

小結:這里演示了使用DMV 排除故障和調查長時間的活動事務的一般技巧。基本步驟如下:
1、查詢獲取會話ID和事務ID之間的映射。
2、查詢和查找會話最新執行的命令(列)
3、最后,查詢s確定事務被打開了多少時間、事務的類型和事務的狀態。
使用這個技巧可以回到應用程序去查明調用的被拋棄的事務(打開但從未提交)以及那些運行時間太長或對于應用程序來說是不必要的不恰當事務。

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

SQL2008中通過DBCCOPENTRAN和會話查詢事務

SQL2008中通過DBCCOPENTRAN和會話查詢事務:無論是有意無意,如果事務在數據庫中保持打開,則它會阻塞其他進程對修改后的數據進行操作。 同樣,對事務日志進行備份也只會截斷不活動事務的那部分事務日志,所以打開的事務會導致日志變多(甚至達到物理限制),直到事務被提交或回滾。 要找到最早的活動
推薦度:
標簽: sql 事務 sqlserver
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 久久99精品久久久久久 | 欧美日韩精品在线观看 | 亚洲欧美另类在线观看 | 精品久久久久中文字幕日本 | 亚洲精品乱码久久久久 | 亚洲国产一成人久久精品 | 欧美91精品久久久久网免费 | 91精品国产免费久久久久久 | 伊人操 | 欧美在线综合视频 | 久久无码精品一区二区三区 | 国产免费资源高清小视频在线观看 | 伊人情人综合成人久久网小说 | 一区二区三区四区免费视频 | 亚洲精品视频区 | 久久国产精品一区二区 | 深夜福利一区二区 | 欧美日韩亚洲国产 | 91精品一区二区三区久久久久 | 亚洲免费在线视频 | 色国产精品一区在线观看 | 劲爆欧美第一页 | 日韩在线观看一区二区三区 | 精品国产一区二区三区19 | 亚洲天堂欧美 | 看全黄大色大黄美女 | 广东东莞一级毛片免费 | 欧州人曾交大全 | 国产一级做a爰片在线看 | 亚洲 欧美 手机 在线观看 | www.a级片| 亚洲欧美日韩另类 | 99久久精品国产一区二区三区 | 亚洲综合日韩 | 国产成人一区在线播放 | 国产一区二区三区免费 | 欧美一区三区 | 国产成人+综合亚洲+天堂 | 国产欧美成人一区二区三区 | 热久久国产 | 国精品日韩欧美一区二区三区 |