自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

鎖定SQL表的語句

數(shù)據(jù)庫 SQL Server
下文對(duì)如何鎖定SQL數(shù)據(jù)庫的一個(gè)表的方法,以及鎖定后可以進(jìn)行的操作語句進(jìn)行了說明,供您參考,希望對(duì)您學(xué)習(xí)SQL數(shù)據(jù)庫有所幫助。

鎖定一個(gè)SQL表的語句是SQL數(shù)據(jù)庫使用者都需要知道的,下面就將為您介紹鎖定SQL表的語句,希望對(duì)您學(xué)習(xí)鎖定SQL表方面能有所幫助。

鎖定數(shù)據(jù)庫的一個(gè)表

SELECT * FROM table WITH (HOLDLOCK)

注意: 鎖定數(shù)據(jù)庫的一個(gè)表的區(qū)別

SELECT * FROM table WITH (HOLDLOCK)

其他事務(wù)可以讀取表,但不能更新刪除

SELECT * FROM table WITH (TABLOCKX)

其他事務(wù)不能讀取表,更新和刪除

SELECT 語句中“加鎖選項(xiàng)”的功能說明

SQL Server提供了強(qiáng)大而完備的鎖機(jī)制來幫助實(shí)現(xiàn)數(shù)據(jù)庫系統(tǒng)的并發(fā)性和高性能。用戶既能使用SQL Server的缺省設(shè)置也可以在select 語句中使用“加鎖選項(xiàng)”來實(shí)現(xiàn)預(yù)期的效果。 本文介紹了SELECT語句中的各項(xiàng)“加鎖選項(xiàng)”以及相應(yīng)的功能說明。

功能說明: 

NOLOCK(不加鎖)

此選項(xiàng)被選中時(shí),SQL Server 在讀取或修改數(shù)據(jù)時(shí)不加任何鎖。 在這種情況下,用戶有可能讀取到未完成事務(wù)(Uncommited Transaction)或回滾(Roll Back)中的數(shù)據(jù), 即所謂的“臟數(shù)據(jù)”。

HOLDLOCK(保持鎖)

此選項(xiàng)被選中時(shí),SQL Server 會(huì)將此共享鎖保持至整個(gè)事務(wù)結(jié)束,而不會(huì)在途中釋放。

UPDLOCK(修改鎖)

此選項(xiàng)被選中時(shí),SQL Server 在讀取數(shù)據(jù)時(shí)使用修改鎖來代替共享鎖,并將此鎖保持至整個(gè)事務(wù)或命令結(jié)束。使用此選項(xiàng)能夠保證多個(gè)進(jìn)程能同時(shí)讀取數(shù)據(jù)但只有該進(jìn)程能修改數(shù)據(jù)。

TABLOCK(表鎖)

此選項(xiàng)被選中時(shí),SQL Server 將在整個(gè)表上置共享鎖直至該命令結(jié)束。 這個(gè)選項(xiàng)保證其他進(jìn)程只能讀取而不能修改數(shù)據(jù)。

PAGLOCK(頁鎖)

此選項(xiàng)為默認(rèn)選項(xiàng), 當(dāng)被選中時(shí),SQL Server 使用共享頁鎖。

TABLOCKX(排它表鎖)

此選項(xiàng)被選中時(shí),SQL Server 將在整個(gè)表上置排它鎖直至該命令或事務(wù)結(jié)束。這將防止其他進(jìn)程讀取或修改表中的數(shù)據(jù)。

HOLDLOCK 持有共享鎖,直到整個(gè)事務(wù)完成,應(yīng)該在被鎖對(duì)象不需要時(shí)立即釋放,等于SERIALIZABLE事務(wù)隔離級(jí)別

NOLOCK 語句執(zhí)行時(shí)不發(fā)出共享鎖,允許臟讀 ,等于 READ UNCOMMITTED事務(wù)隔離級(jí)別

PAGLOCK 在使用一個(gè)表鎖的地方用多個(gè)頁鎖

READPAST 讓sql server跳過任何鎖定行,執(zhí)行事務(wù),適用于READ UNCOMMITTED事務(wù)隔離級(jí)別只跳過RID鎖,不跳過頁,區(qū)域和表鎖

ROWLOCK 強(qiáng)制使用行鎖

TABLOCKX 強(qiáng)制使用獨(dú)占表級(jí)鎖,這個(gè)鎖在事務(wù)期間阻止任何其他事務(wù)使用這個(gè)表

UPLOCK 強(qiáng)制在讀表時(shí)使用更新而不用共享鎖

注意: 鎖定數(shù)據(jù)庫的一個(gè)表的區(qū)別

SELECT * FROM table WITH (HOLDLOCK) 其他事務(wù)可以讀取表,但不能更新刪除

SELECT * FROM table WITH (TABLOCKX) 其他事務(wù)不能讀取表,更新和刪除
 

 

 

【編輯推薦】
 

SQL條件語句實(shí)例

SQL整體更新的方法

SQL中IS NULL的語法

巧用SQL server臨時(shí)表

速學(xué)如何定義SQL存儲(chǔ)過程

責(zé)任編輯:段燃 來源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-09-03 15:47:40

SQL語句鎖定

2010-09-26 15:23:24

SQL語句

2010-09-28 15:07:14

SQL語句

2010-09-27 10:04:30

Sql Update語

2010-10-13 09:30:45

SQL Server

2010-09-07 11:04:14

SQL語句

2010-09-26 16:56:14

sql語句

2010-09-25 15:37:38

SQL語句

2011-06-02 10:20:09

SQL主從關(guān)系

2010-09-25 16:42:45

sql語句

2010-09-07 14:22:41

SQL語句

2010-09-25 15:26:45

SQL查詢語句

2010-09-02 09:51:24

SQL刪除

2023-03-30 09:10:06

SQLSELECTFROM

2010-09-03 14:39:15

SQLSELECT語句

2024-01-03 17:42:32

SQL數(shù)據(jù)庫

2010-09-01 11:46:01

DB2臨時(shí)表SQL

2011-05-18 13:16:21

MySQL數(shù)據(jù)庫鎖定

2010-09-03 14:47:50

SQLSELECT語句

2010-07-08 13:26:02

SQL Server
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)