Nota
O acesso a esta página requer autorização. Pode tentar iniciar sessão ou alterar os diretórios.
O acesso a esta página requer autorização. Pode tentar alterar os diretórios.
Aplica-se a:SQL Server
Azure SQL Database
Azure SQL Managed Instance
Azure Synapse Analytics
Sistema de Plataforma de Análise (PDW)
Armazém no Microsoft Fabric
Base de dados SQL no Microsoft Fabric
Define o BEGIN TRANSACTION modo como implícito, para a ligação.
Transact-SQL convenções de sintaxe
Sintaxe
SET IMPLICIT_TRANSACTIONS { ON | OFF }
Observações
Quando ON, o sistema está em modo de transação implícita . Isto significa que se @@TRANCOUNT = 0, qualquer uma das seguintes instruções Transact-SQL inicia uma nova transação. É equivalente a um invisible BEGIN TRANSACTION ser executado primeiro:
ALTER TABLEBEGIN TRANSACTIONCREATEDELETEDROPFETCHGRANTINSERTMERGEOPENREVOKE-
SELECT(Ver observação esclarecedora) TRUNCATE TABLEUPDATE
Quando OFF, cada uma das instruções T-SQL anteriores é limitada por uma instrução invisível BEGIN TRANSACTION e uma não vista COMMIT TRANSACTION . Quando OFF, dizemos que o modo de transação é autocommit. Se o seu código T-SQL emitir visivelmente um BEGIN TRANSACTION, dizemos que o modo de transação é explícito.
Existem vários pontos clarificadores a compreender:
Quando o modo de transação é implícito, não é emitido nenhum invisível
BEGIN TRANSACTION, se@@TRANCOUNT > 0já for. No entanto, quaisquer afirmações explícitasBEGIN TRANSACTIONainda incrementam@@TRANCOUNT.Quando os seus
INSERTextratos e qualquer outra coisa da sua unidade de trabalho estiverem concluídos, deve emitirCOMMIT TRANSACTIONextratos até@@TRANCOUNTque seja decrementado novamente para 0. Ou pode emitir um.ROLLBACK TRANSACTION
SELECTInstruções que não selecionam de uma tabela não iniciam transações implícitas. Por exemplo,SELECT GETDATE();ouSELECT 1, 'ABC';não exigem transações.Transações implícitas podem, de forma inesperada, dever-se
ONa incumprimentos ANSI. Para mais detalhes, veja SET ANSI_DEFAULTS.Definir
IMPLICIT_TRANSACTIONSparaONnão é popular. Na maioria dos casos em queIMPLICIT_TRANSACTIONSéON, é porqueSET ANSI_DEFAULTS ONfoi definido.O SQL Server Native Client OLE DB Provider para SQL Server, e o driver SQL Server Native Client ODBC, são automaticamente definidos
IMPLICIT_TRANSACTIONScomoOFFao ligar-se. DefinaIMPLICIT_TRANSACTIONSos padrões paraOFFligações com o fornecedor gerido SQLClient e para pedidos SOAP recebidos através de endpoints HTTP.
Para visualizar a definição atual para IMPLICIT_TRANSACTIONS, execute a seguinte consulta.
DECLARE @IMPLICIT_TRANSACTIONS AS VARCHAR (3) = 'OFF';
IF ((2 & @@OPTIONS) = 2)
SET @IMPLICIT_TRANSACTIONS = 'ON';
SELECT @IMPLICIT_TRANSACTIONS AS IMPLICIT_TRANSACTIONS;
Examples
O script de Transact-SQL seguinte executa alguns casos de teste diferentes. Também é fornecido o texto de saída, que mostra o comportamento detalhado e os resultados de cada caso de teste.
-- Preparations.
SET NOCOUNT ON;
SET IMPLICIT_TRANSACTIONS OFF;
GO
WHILE (@@TRANCOUNT > 0) COMMIT TRANSACTION;
GO
IF (OBJECT_ID(N'dbo.t1',N'U') IS NOT NULL) DROP TABLE dbo.t1;
GO
CREATE table dbo.t1 (a INT);
GO
PRINT N'-------- [Test A] ---- OFF ----';
PRINT N'[A.01] Now, SET IMPLICIT_TRANSACTIONS OFF.';
PRINT N'[A.02] @@TRANCOUNT, at start, == ' + CAST(@@TRANCOUNT AS NVARCHAR(10));
SET IMPLICIT_TRANSACTIONS OFF;
GO
INSERT INTO dbo.t1 VALUES (11);
INSERT INTO dbo.t1 VALUES (12);
PRINT N'[A.03] @@TRANCOUNT, after INSERTs, == ' + CAST(@@TRANCOUNT AS NVARCHAR(10));
GO
PRINT N' ';
PRINT N'-------- [Test B] ---- ON ----';
PRINT N'[B.01] Now, SET IMPLICIT_TRANSACTIONS ON.';
PRINT N'[B.02] @@TRANCOUNT, at start, == ' + CAST(@@TRANCOUNT AS NVARCHAR(10));
SET IMPLICIT_TRANSACTIONS ON;
GO
INSERT INTO dbo.t1 VALUES (21);
INSERT INTO dbo.t1 VALUES (22);
PRINT N'[B.03] @@TRANCOUNT, after INSERTs, == ' + CAST(@@TRANCOUNT AS NVARCHAR(10));
GO
COMMIT TRANSACTION;
PRINT N'[B.04] @@TRANCOUNT, after COMMIT, == ' + CAST(@@TRANCOUNT AS NVARCHAR(10));
GO
PRINT N' ';
PRINT N'-------- [Test C] ---- ON, then BEGIN TRAN ----';
PRINT N'[C.01] Now, SET IMPLICIT_TRANSACTIONS ON.';
PRINT N'[C.02] @@TRANCOUNT, at start, == ' + CAST(@@TRANCOUNT AS NVARCHAR(10));
SET IMPLICIT_TRANSACTIONS ON;
GO
BEGIN TRANSACTION;
INSERT INTO dbo.t1 VALUES (31);
INSERT INTO dbo.t1 VALUES (32);
PRINT N'[C.03] @@TRANCOUNT, after INSERTs, == ' + CAST(@@TRANCOUNT AS NVARCHAR(10));
GO
COMMIT TRANSACTION;
PRINT N'[C.04] @@TRANCOUNT, after a COMMIT, == ' + CAST(@@TRANCOUNT AS NVARCHAR(10));
COMMIT TRANSACTION;
PRINT N'[C.05] @@TRANCOUNT, after another COMMIT, == ' + CAST(@@TRANCOUNT AS NVARCHAR(10));
GO
PRINT N' ';
PRINT N'-------- [Test D] ---- ON, INSERT, BEGIN TRAN, INSERT ----';
PRINT N'[D.01] Now, SET IMPLICIT_TRANSACTIONS ON.';
PRINT N'[D.02] @@TRANCOUNT, at start, == ' + CAST(@@TRANCOUNT AS NVARCHAR(10));
SET IMPLICIT_TRANSACTIONS ON;
GO
INSERT INTO dbo.t1 VALUES (41);
BEGIN TRANSACTION;
INSERT INTO dbo.t1 VALUES (42);
PRINT N'[D.03] @@TRANCOUNT, after INSERTs, == ' + CAST(@@TRANCOUNT AS NVARCHAR(10));
GO
COMMIT TRANSACTION;
PRINT N'[D.04] @@TRANCOUNT, after a COMMIT, == ' + CAST(@@TRANCOUNT AS NVARCHAR(10));
COMMIT TRANSACTION;
PRINT N'[D.05] @@TRANCOUNT, after another COMMIT, == ' + CAST(@@TRANCOUNT AS NVARCHAR(10));
GO
-- Clean up.
SET IMPLICIT_TRANSACTIONS OFF;
GO
WHILE (@@TRANCOUNT > 0) COMMIT TRANSACTION;
GO
DROP TABLE dbo.t1;
GO
A seguir vem a saída de texto do script Transact-SQL anterior.
-------- [Test A] ---- OFF ----
[A.01] Now, SET IMPLICIT_TRANSACTIONS OFF.
[A.02] @@TRANCOUNT, at start, == 0
[A.03] @@TRANCOUNT, after INSERTs, == 0
-------- [Test B] ---- ON ----
[B.01] Now, SET IMPLICIT_TRANSACTIONS ON.
[B.02] @@TRANCOUNT, at start, == 0
[B.03] @@TRANCOUNT, after INSERTs, == 1
[B.04] @@TRANCOUNT, after COMMIT, == 0
-------- [Test C] ---- ON, then BEGIN TRAN ----
[C.01] Now, SET IMPLICIT_TRANSACTIONS ON.
[C.02] @@TRANCOUNT, at start, == 0
[C.03] @@TRANCOUNT, after INSERTs, == 2
[C.04] @@TRANCOUNT, after a COMMIT, == 1
[C.05] @@TRANCOUNT, after another COMMIT, == 0
-------- [Test D] ---- ON, INSERT, BEGIN TRAN, INSERT ----
[D.01] Now, SET IMPLICIT_TRANSACTIONS ON.
[D.02] @@TRANCOUNT, at start, == 0
[D.03] @@TRANCOUNT, after INSERTs, == 2
[D.04] @@TRANCOUNT, after a COMMIT, == 1
[D.05] @@TRANCOUNT, after another COMMIT, == 0
Conteúdo relacionado
- ALTERAR TABELA (Transact-SQL)
- INICIAR TRANSAÇÃO (Transact-SQL)
- CRIAR TABELA (Transact-SQL)
- SUPRIMIR (Transact-SQL)
- MESA SUSPENSA (Transact-SQL)
- BUSCAR (Transact-SQL)
- SUBVENÇÃO (Transact-SQL)
- INSERIR (Transact-SQL)
- MESCLAR (Transact-SQL)
- ABERTO (Transact-SQL)
- REVOGAR (Transact-SQL)
- SELECIONAR (Transact-SQL)
- Instruções SET (Transact-SQL)
- CONJUNTO ANSI_DEFAULTS (Transact-SQL)
- @@TRANCOUNT (Transact-SQL)
- TABELA TRUNCADA (Transact-SQL)
- ATUALIZAÇÃO (Transact-SQL)