sp_getbindtoken (Transact-SQL)

 

DIESES THEMA GILT FÜR:jaSQL Server (ab 2008)neinAzure SQL-DatenbankneinAzure SQL Data Warehouse neinParallel Data Warehouse

Gibt einen eindeutigen Bezeichner für die Transaktion zurück. Dieser eindeutige Bezeichner ist eine Zeichenfolge, mit der Sitzungen mithilfe von sp_bindsession gebunden werden.

System_CAPS_ICON_important.jpg Wichtig


Dieses Feature wird in einer künftigen Version von Microsoft SQL Server entfernt. Verwenden Sie diese Funktion beim Entwickeln neuer Anwendungen nicht, und planen Sie das Ändern von Anwendungen, in denen es zurzeit verwendet wird. Verwenden Sie stattdessen Multiple Active Results Sets (MARS) oder verteilte Transaktionen. Weitere Informationen finden Sie unter mithilfe mehrerer Active Result Sets (MARS).

Gilt für: SQL Server (SQL Server 2008 bis zur aktuellen Version).

Topic link icon Transact-SQL-Syntaxkonventionen

  
sp_getbindtoken [@out_token =] 'return_value' OUTPUT   

[@out_token= ]'return_value'
Das Token, das zum Binden von Sitzungen verwendet wird. Rückgabewert ist varchar(255) hat keinen Standardwert.

Keine

Keine

Sp_getbindtoken gibt ein gültiges Token zurück, nur, wenn die gespeicherte Prozedur innerhalb einer aktiven Transaktion ausgeführt wird. Andernfalls gibt Datenbankmodul eine Fehlermeldung zurück. Beispiel:

-- Declare a variable to hold the bind token.  
-- No active transaction.  
DECLARE @bind_token varchar(255);  
-- Trying to get the bind token returns an error 3921.  
EXECUTE sp_getbindtoken @bind_token OUTPUT;  
Server: Msg 3921, Level 16, State 1, Procedure sp_getbindtoken, Line 4  
Cannot get a transaction token if there is no transaction active.  
Reissue the statement after a transaction has been started.  

Wenn Sp_getbindtoken zum Eintragen einer verteilten transaktionsverbindung innerhalb einer geöffneten Transaktion verwendet wird SQL Server das gleiche Token zurück. Beispiel:

USE AdventureWorks2012;  
GO  
DECLARE @bind_token varchar(255);  
  
BEGIN TRAN;  
  
EXECUTE sp_getbindtoken @bind_token OUTPUT;  
SELECT @bind_token AS Token;  
  
BEGIN DISTRIBUTED TRAN;  
  
EXECUTE sp_getbindtoken @bind_token OUTPUT;  
SELECT @bind_token AS Token;  

Beide SELECT-Anweisungen geben dasselbe Token zurück:

Token  
-----  
PKb'gN5<9aGEedk_16>8U=5---/5G=--  
(1 row(s_) affected)  
  
Token  
-----  
PKb'gN5<9aGEedk_16>8U=5---/5G=--  
(1 row(s_) affected)  

Das Bindungstoken kann zusammen mit sp_bindsession verwendet werden, um neue Sitzungen an dieselbe Transaktion zu binden. Das Bindungstoken ist nur lokal innerhalb jeder Instanz von Datenbankmodul gültig und kann nicht für mehrere Instanzen freigegeben werden.

Zum Erhalten und Übergeben eines Bindungstokens muss sp_getbindtoken vor sp_bindsession ausgeführt werden, um denselben Sperrbereich gemeinsam verwenden zu können. Wenn Sie ein Bindungstoken erhalten, wird sp_bindsession ordnungsgemäß ausgeführt.

System_CAPS_ICON_note.jpg Hinweis


Um ein Bindungstoken zu erhalten, das von einer erweiterten gespeicherten Prozedur verwendet werden kann, sollte die API-Funktion srv_getbindtoken von Open Data Services verwendet werden.

Erfordert die Mitgliedschaft in der public-Rolle.

Im folgenden Beispiel wird ein Bindungstoken erhalten und der Bindungstokenname angezeigt.

DECLARE @bind_token varchar(255);  
BEGIN TRAN;  
EXECUTE sp_getbindtoken @bind_token OUTPUT;  
SELECT @bind_token AS Token;  

Im Folgenden finden Sie das Resultset.

Token

----------------------------------------------------------

\0]---5^PJK51bP<1F<-7U-]ANZ

Sp_bindsession (Transact-SQL)
Gespeicherte Systemprozeduren (Transact-SQL)
Srv_getbindtoken (API für gespeicherte Prozeduren erweitert)

Community-Beiträge

HINZUFÜGEN
Anzeigen: