2025 Auteur: Lynn Donovan | [email protected]. Laatst gewijzigd: 2025-01-13 06:17
Standaard is een DML statement dat wordt uitgevoerd zonder dat er expliciet een transactie wordt gestart, wordt automatisch vastgelegd bij succes of wordt teruggedraaid bij een mislukking aan het einde van het statement. Dit gedrag heet automatisch vastleggen . Dit gedrag wordt gecontroleerd met de AUTOCOMMIT parameter.
Hiervan, is DDL een Autocommit?
Een SQL-instructie uitgevoerd in automatisch vastleggen modus kan niet worden teruggedraaid. De meeste DBMS (bijv. MariaDB) forceren automatisch vastleggen voor iedere DDL verklaring zelfs innon- automatisch vastleggen modus. Voordat DDL statement startvorige DML statements in transactie zijn (auto)committed. Elk DDL wordt uitgevoerd in eigen nieuwe automatisch vastleggen transactie.
Bovendien, is SQL Server Autocommit? Automatisch vastleggen modus is de standaard transactiebeheermodus van de SQL-server Database-engine. Elke Transact- SQL statement wordt vastgelegd of teruggedraaid wanneer het is voltooid.
Kunnen DML-statements op deze manier worden teruggedraaid?
Het effect van een DML-instructie is niet permanent totdat u de transactie uitvoert die deze omvat. Een transactie is een reeks van SQL uitspraken die Oracle Database behandelt als een eenheid (it kan vrijgezel zijn DML-instructie ). Totdat een transactie is gepleegd, is het kan zijn terug gerold (ongedaan gemaakt).
Vereist truncate commit?
En een belangrijk punt - hoewel TRUNCATE TABLE lijkt op een DELETE zonder WHERE-clausule, TRUNCATE is geen DML, het is DDL. VERWIJDEREN vereist een VERBINDEN , maar TRUNCATEdoet niet.