Skip to content
The latest version of DbVisualizer was released 2024-12-04DOWNLOAD HERE ->

Auto Commit, Commit and Rollback

With Auto Commit enabled, all changes you make to the database data is automatically committed after the successful execution of an SQL statement. Auto Commit is enabled for a connection by default. You can change the default in the Options area of the Object View tab for the connection. Note that this change can only be done when the connection is disconnected.

You can toggle the Auto Commit setting for an open SQL Commander tab using the SQL Commander main menu item of the corresponding button in the SQL Commander toolbar. The setting is also available both on the right-click menu under the Transaction menu item.

Not all databases supports transactions and thus always commits executions

Alternatively, you can use this command in a script to set it:

@set autocommit on/off;

If Auto Commit is disabled, it is very important to manually issue the commit or rollback operations when appropriate. Use the Commit and Rollback buttons in the SQL Commander toolbar or the corresponding operations in the SQL Commander main menu to commit and rollback transactions.

Alternatively, you can use the following commands in a script executed in the SQL Commander:

@commit;
@rollback;

There is an Auto-Commit: ON/OFF indicator in the editor status bar; the first number shows the number of records updated in the database since the last commit/rollback, the second shows the number of statements (except SELECTs) executed since last commit/rollback.

Screenshot of the Auto Commit indicator in the editor status bar

When performing certain actions like disconnecting, or closing a tab with a connection that has uncommitted records, a prompt will appear and ask what to do with those records. When disconnecting, the choice to Continue with Uncommitted is replaced with Cancel.

Auto Commit Off Dialog

Having Auto Commit off for a connection should be handled with great care since transactions may lock parts of the database (this is database dependent). To minimize the risk of forgetting uncommitted transactions, there is an Ask when Auto Commit is OFF settings in the connection Properties tab, in the Transactions category, that can be set to warn you when there are changes that hasn't been committed. You can set it to Always or When Uncommitted Updates. When set to When Uncommitted Updates, you are warned when there is at least one updated record reported by the database. For database that do not accurately report updated records, you can set it to Always to be warned if at least one statement (other than SELECT) has been executed since the last commit or rollback.

There is also a Pending Transactions at Disconnect setting in the Tool Properties dialog, in the Transaction category under the General tab. It specifies what DbVisualizer should do when you disconnect a connection that has pending changes, and you can set it to Commit, Rollback or Ask.