SQLServerのテーブルロック状態を取得するSQL

公開日: : 最終更新日:2016/07/19 SQL Server , , ,

SQLServerのデッドロックを調査している中で
ロックの状態を調べるSQLがあることが
判明したのでメモします。

ロックの状態を取得するSQL

ロックの状態を取得するSQLは以下のようにすれば取得できるようです。
(参考ページ:ロックの状態を調べる

SQLの実行結果

上記のSQL実行結果は


ロックの種類

ロックの種類は以下のものになります。

S 共有ロック 他のトランザクションからの読込は可能。更新は不可となる。
X 排他ロック 他のトランザクションからの読込・更新が共に不可となる。
INSERT、UPDATE、DELETEを実行するとこのロックになる。
U 更新ロック 他のトランザクションからの読込は可能。更新は不可となる。
SELECTで WITH( UPDLOCK )を指定するとこのロックになる。
IS インテント共有 下位の階層に位置するリソースの (すべてではなく)
一部に対し、要求されているかかけられている共有ロックを保護します。
IX インテント排他 下位の階層に位置するリソースの (すべてではなく)
一部に対し、要求されているかかけられている排他ロックを保護します。
IX は IS のスーパーセットです。また、下位のリソースに対する共有ロックの要求を保護します。
SIX インテント排他の共有 下位の階層に位置するすべてのリソースに対し、
要求されているかかけられている共有ロックを保護し、下位のリソースの (すべてではなく)
一部のインテント排他ロックを保護します。
上位リソースで同時実行している IS ロックは可能です。
たとえば、テーブルに対し SIX ロックをかけると、
変更中のページにインテント排他ロックが、変更中の行に排他ロックがかかります。
1 つのリソースに対しては、一度に1つのSIXロックしかかけられません。
その結果、他のトランザクションによってリソースが更新されることはなくなりますが、
他のトランザクションはテーブルレベルのISロックをかけることで
下位のリソースを読み取ることができます。
IU インテント更新 下位の階層に位置するすべてのリソースに対し、要求されているかかけられている更新ロックを保護します。
IU ロックはページ リソースに対してのみ使用します。
更新操作が発生すると、IU ロックは IX ロックに変換されます。
SIU 共有インテント更新 SロックとIUロックを個別にかけるか、同時にかけるかして組み合わせたものです。
たとえば、トランザクションで PAGLOCK ヒントを指定してクエリを実行してから更新操作を実行するとします。
PAGLOCK ヒントを指定したクエリでSロックをかけ、更新操作で IU ロックをかけます。
UIX 更新インテント排他 UロックとIXロックを個別にかけるか、同時にかけるかして組み合わせたものです。
スポンサーリンク
スポンサーリンク
  • このエントリーをはてなブックマークに追加
  • 13 follow us in feedly

関連記事

CASE WHEN を使って条件ごとの件数を取得する

CASE WHEN を使って条件ごとの件数を取得する あるテーブルに状態を表すフラグを持たせること

記事を読む

DATENAME関数を使って日付を取得する。

DATENAME関数を使って日付取得 SQLServerでDATENAME関数を使って日付を取得し

記事を読む

SQLServerのバージョン番号を取得する方法

SQLServerのバージョン番号を取得する SQLServerのバージョン番号は「@@VERSI

記事を読む

SQLで前の行と同じ値は表示しないようにする

前の行と同じ値は表示しない SQLで前の行と同じ値は表示しないようにするして 伝票印刷のような処

記事を読む

SQLServer

SQLServerで累積値(累積比)を求める

SQLServerで累積値(累積比)を求める SQLServerで累積値(累積比)を求めるには

記事を読む

ISNULL()関数を使ってSQLでIF文を使わずに条件を分岐する

ISNULLをIF文の代わりに使ってみる SQLでIFを書けばWHERE句の内容を変えて検索できま

記事を読む

SQLで大文字、小文字変換を行う

SQLで大文字⇔子文字変換を行う SQLで大文字⇔小文字変換を行うには「UPPER関数」と「LOW

記事を読む

ALTER TABLEで既存のテーブルのプライマリーキー(主キー)を変更する

ALTER TABLEで既存のテーブルのプライマリーキー(主キー)を変更する ALTER TA

記事を読む

SQLサーバ

連番中で 「歯抜け」の番号を見つけ出すSQL

テーブル内の連番の歯抜け番号を探す よくある処理でテーブルに設定されている連番の中で 「歯抜け」

記事を読む

CREATE TABLE,ALTER TABLEでテーブルのプライマリーキー(PK)を作成する

SQL ServerでSQLを使用してプライマリーキー(PK)を作成します。 テーブル作成時(

記事を読む

SQLで日付範囲の重複をチェックする

SQLで日付範囲の重複をチェックする SQLで日付範囲の重複をチェッ

SQLServer
テーブルのプライマリキー(PK)を取得する(SQL編)

SQLServerでテーブルのプライマリキー(PK)をSQLで取得する

2つのテーブルを結合して値を更新するSQL

2つのテーブルを結合して値を更新するSQL テーブルAの値をテーブル

CASE WHEN を使って条件ごとの件数を取得する

CASE WHEN を使って条件ごとの件数を取得する あるテーブルに

DATENAME関数を使って日付を取得する。

DATENAME関数を使って日付取得 SQLServerでDATEN

→もっと見る



PAGE TOP ↑