És DML Autocommit?
És DML Autocommit?

Vídeo: És DML Autocommit?

Vídeo: És DML Autocommit?
Vídeo: 6. What is Transaction Control Language? Using COMMIT, ROLLBACK and SAVEPOINT commands in MySQL. 2024, Abril
Anonim

Per defecte, a DML La declaració executada sense iniciar explícitament una transacció es confirma automàticament en cas d'èxit o es revertirà en cas de fallada al final de la sentència. Aquest comportament s'anomena autocommit . Aquest comportament es controla amb el AUTOCOMMIT paràmetre.

Per tant, DDL és un Autocommit?

Una sentència SQL executada a autocommit mode no es pot revertir. La majoria de DBMS (per exemple, MariaDB) força autocommit per cada DDL declaració fins i tot inno- autocommit mode. Abans DDL La declaració comença les declaracions DML anteriors de la transacció es comprometen (automàticament). Cadascú DDL s'executa en nova pròpia autocommit transacció.

A més, SQL Server és Autocommit? Compromís automàtic mode és el mode de gestió de transaccions predeterminat del SQL Server Motor de base de dades. Totes les transaccions- SQL La declaració es confirma o es torna enrere quan es completa.

D'aquesta manera, es poden revertir les declaracions DML?

L'efecte d'a Declaració DML no és permanent fins que comprometeu la transacció que l'inclou. Una transacció és una seqüència d'SQL declaracions que Oracle Database tracta com a unitat (it llauna ser solter Declaració DML ). Fins que no es cometi una transacció, això llauna ser enrere (desfet).

Truncat requereix commit?

I un punt clau, encara que TRUNCAR TABLE sembla una DELETE sense clàusula WHERE, TRUNCAR no és DML, és DDL. ELIMINAR requereix a COMPROMÈS , però TRUNCATEfa no.

Recomanat: