成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SQL Server 2008通過DBCC OPENTRAN和會話查詢事務詳解

數據庫 SQL Server
本文我們主要介紹了SQL Server 2008通過DBCC OPENTRAN和會話查詢事務的相關知識,并給出了實際的例子加以說明,希望本次的介紹能夠對您有所幫助。

SQL Server 2008通過DBCC OPENTRAN會話查詢事務是本文我們主要要介紹的內容,無論是有意無意,如果事務在數據庫中保持打開,則它會阻塞其他進程對修改后的數據進行操作。同樣,對事務日志進行備份也只會截斷不活動事務的那部分事務日志,所以打開的事務會導致日志變多(甚至達到物理限制),直到事務被提交或回滾。要找到最早的活動事務,可以使用DBCC OPENTRAN命令。詳細用法見MSDN:http://msdn.microsoft.com/zh-cn/library/ms182792.aspx。

給出一個示例:

  1. CREATE TABLE T_Product(PKID int, PName Nvarchar(50));  
  2. GO  
  3.  
  4. BEGIN TRAN  
  5. INSERT INTO T_Product VALUES (101, '嫦娥四號');  
  6. GO  
  7. DBCC OPENTRAN;  
  8. ROLLBACK TRAN;  
  9. GO  
  10. DROP TABLE T_Product;  
  11. GO 

執行結果:

  1. /*    
  2. (1 row(s) affected)   
  3. 數據庫 'Testdb' 的事務信息。  
  4. 最早的活動事務:  
  5. SPID (服務器進程 ID): 54  
  6. UID (用戶 ID): -1  
  7. 名稱 : user_transaction  
  8. LSN : (295:6687:1)  
  9. 開始時間 : 12 24 2010 2:50:15:607PM  
  10. SID : 0x0105000000000005150000007fe010d31cba1ab1566ac5dff4010000DBCC 執行完畢。如果 DBCC 輸出了錯誤信息,請與系統管理員聯系。  
  11. */ 

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

我們看一個實例:

  1. SET Transaction isolation level serializable  
  2. BEGIN TRAN  
  3. select * from T_Product  
  4. Insert into T_Product   
  5. select 'OATest' union all  
  6. select 'OAPlay' 

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

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

執行結果: 

  1. /*返回結果  
  2. session_id transaction_id is_user_transaction is_local  
  3. 54 489743 1 1  
  4. */ 

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

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

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

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

結果:

  1. /*  
  2. transaction_begin_time tran_Type transaction_state  
  3. 2010-12-24 14:05:29.170 Read/Write transaction active  
  4. */ 

小結:這里演示了使用DMV 排除故障和調查長時間的活動事務的一般技巧。

基本步驟如下:

1、查詢sys.dm_tran_session_transactions獲取會話ID和事務ID之間的映射;

2、查詢sys.dm_exec_connections和sys.dm_exec_sql_text查找會話最新執行的命令(most_recent_sql_Handle列);

3、最后,查詢sys.dm_tran_active_transactions確定事務被打開了多少時間、事務的類型和事務的狀態。使用這個技巧可以回到應用程序去查明調用的被拋棄的事務(打開但從未提交)以及那些運行時間太長或對于應用程序來說是不必要的不恰當事務。

關于SQL Server 2008通過DBCC OPENTRAN和會話查詢事務的相關知識就介紹到這里了,希望本次的介紹能夠對您有所收獲!

 【編輯推薦】

  1. SQL Server多表查詢優化方案總結
  2. SQL Server數據庫ISNULL函數的應用實例
  3. SQL Server數據庫DATEPART的語法及使用實例
  4. SQL Server根據子節點查詢所有父節點的代碼示例
  5. SQL Server臟讀方式數據提取之NOLOCK和READPAST
責任編輯:趙鵬 來源: 博客園
相關推薦

2011-07-27 18:09:18

2009-03-17 13:25:13

查詢遷移SQL Server

2010-11-08 09:04:00

SQL Server

2011-03-15 10:22:42

SQL Server 聯機事務處理

2010-10-11 09:05:40

SQL Server

2010-06-17 10:43:21

SQL Server

2010-07-26 09:34:24

SQL Server性

2010-07-19 17:44:26

Telnet命令

2022-09-05 08:33:32

HartKubernetes

2010-10-14 09:32:52

SQL Server

2010-05-13 10:00:10

SQL Server

2013-05-08 10:01:55

SQL Server 數據備份備份與還原

2009-09-29 14:00:00

CCNA考試心得CCNA

2009-10-09 16:14:00

CCNA考試心得CCNA

2011-08-19 10:40:27

SQL Server Merge命令

2011-09-01 19:00:08

SQL ServerDBCC語句

2009-04-08 09:29:34

SQL Server新特性Resource Go

2011-08-19 11:00:54

SQL Server WaitFor命令

2010-07-09 17:25:14

SQL Server數

2011-08-25 13:41:50

SQL Server 變更跟蹤
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 97色在线视频 | 激情av在线| 97在线观视频免费观看 | aaaaaaa片毛片免费观看 | 国内久久 | 国产日韩精品视频 | 一区二区三区国产精品 | 国产美女在线看 | 精品麻豆剧传媒av国产九九九 | 欧美久久免费观看 | 精品亚洲一区二区 | 91亚洲欧美 | 日韩播放 | av成年人网站 | 欧美一级黄色片免费观看 | 国产97在线视频 | 欧美 视频 | 婷婷一级片 | 国产高清精品在线 | 午夜免费福利片 | 国产日韩欧美激情 | 亚洲日本一区二区 | av一级久久 | 国产精品久久久久久久久久免费看 | 黄色大片免费看 | av中文字幕在线播放 | 龙珠z国语版在线观看 | 国产视频一区二区 | 国产精品久久久久久吹潮 | 亚洲欧美中文日韩在线v日本 | 一级黄色夫妻生活 | 免费观看a级毛片在线播放 黄网站免费入口 | 亚洲一区日韩 | 一区二区三区欧美 | 久久精品亚洲一区二区三区浴池 | 国产一级电影在线观看 | 亚洲精品日韩一区二区电影 | 成人做爰9片免费看网站 | 91麻豆精品一区二区三区 | 国产成人高清视频 | 中文字幕一区二区三区在线观看 |