문서를 영문으로 보려면 영문 확인란을 선택하세요. 마우스 포인터를 텍스트 위로 이동시켜 팝업 창에서 영문 텍스트를 표시할 수도 있습니다.
번역
영문

APPLOCK_MODE(Transact-SQL)

특정 응용 프로그램 리소스에 대해 잠금 소유자가 보유한 잠금 모드를 반환합니다. APPLOCK_MODE는 응용 프로그램 잠금 함수이며 현재 데이터베이스에서 작동합니다. 응용 프로그램 잠금의 범위는 데이터베이스입니다.

항목 링크 아이콘 Transact-SQL 구문 표기 규칙

APPLOCK_MODE( 'database_principal' , 'resource_name' , 'lock_owner' )

'database_principal'

데이터베이스의 개체에 대한 사용 권한이 부여될 수 있는 사용자, 역할 또는 응용 프로그램 역할입니다. 함수를 성공적으로 호출하려면 이 함수의 호출자가 database_principal, dbo 또는 db_owner 고정 데이터베이스 역할의 멤버여야 합니다.

'resource_name'

클라이언트 응용 프로그램이 지정한 잠금 리소스의 이름입니다. 응용 프로그램은 리소스 이름이 고유한지 확인해야 합니다. 지정된 이름은 SQL Server 잠금 관리자에 저장할 수 있는 값으로 내부적으로 해시됩니다. resource_namenvarchar(255)이며 기본값은 없습니다. resource_name은 이진 비교되며 현재 데이터베이스의 데이터 정렬 설정에 관계없이 대/소문자를 구분합니다.

'lock_owner'

잠금의 소유자이며 잠금이 요청될 때 lock_owner 값입니다. lock_ownernvarchar(32)이며 값은 Transaction(기본값) 또는 Session이 될 수 있습니다

nvarchar(32)

특정 응용 프로그램 리소스에 대해 잠금 소유자가 보유한 잠금 모드를 반환합니다. 잠금 모드는 다음 값 중 하나일 수 있습니다.

NoLock

Update

*SharedIntentExclusive

IntentShared

IntentExclusive

*UpdateIntentExclusive

Shared

Exclusive

 

*이 잠금 모드는 다른 잠금 모드의 조합이며 sp_getapplock을 사용하여 명시적으로 설정될 수 없습니다.

Nondeterministic

Nonindexable

Nonparallelizable

별도의 세션을 갖는 두 명의 사용자(User A와 User B)가 다음의 Transact-SQL 문 시퀀스를 실행합니다.

User A는 다음을 실행합니다.

USE AdventureWorks2012;
GO
BEGIN TRAN;
DECLARE @result int;
EXEC @result=sp_getapplock
    @DbPrincipal='public',
    @Resource='Form1',
    @LockMode='Shared',
    @LockOwner='Transaction';
SELECT APPLOCK_MODE('public', 'Form1', 'Transaction');
GO

그런 다음 User B는 다음을 실행합니다.

Use AdventureWorks2012;
GO
BEGIN TRAN;
SELECT APPLOCK_MODE('public', 'Form1', 'Transaction');
--Result set: NoLock

SELECT APPLOCK_TEST('public', 'Form1', 'Shared', 'Transaction');
--Result set: 1 (Lock is grantable.)

SELECT APPLOCK_TEST('public', 'Form1', 'Exclusive', 'Transaction');
--Result set: 0 (Lock is not grantable.)
GO

그런 다음 User A는 다음을 실행합니다.

EXEC sp_releaseapplock @Resource='Form1', @DbPrincipal='public';
GO

그런 다음 User B는 다음을 실행합니다.

SELECT APPLOCK_TEST('public', 'Form1', 'Exclusive', 'Transaction');
--Result set: '1' (The lock is grantable.)
GO

그런 다음 User A와 User B는 다음을 실행합니다.

COMMIT TRAN;
GO

커뮤니티 추가 항목

추가
표시: