Read our blogs, tips and tutorials
Try our exercises or test your skills
Watch our tutorial videos or shorts
Take a self-paced course
Read our recent newsletters
License our courseware
Book expert consultancy
Buy our publications
Get help in using our site
546 attributed reviews in the last 3 years
Refreshingly small course sizes
Outstandingly good courseware
Whizzy online classrooms
Wise Owl trainers only (no freelancers)
Almost no cancellations
We have genuine integrity
We invoice after training
Review 30+ years of Wise Owl
View our top 100 clients
Search our website
We also send out useful tips in a monthly email newsletter ...
Written by Andrew Gould
In this tutorial
Normally, when you change data in a SQL database, such as inserting new records, or deleting or updating existing records, you don't get the opportunity to undo your changes. If you begin a transaction before you modify your data, however, you do have the chance to undo your changes if things go wrong.
To have the opportunity to undo changes made to your data you must begin a transaction before you attempt to make those changes. You can begin a transaction with the BEGIN TRANSACTION statement, as shown below:
--Begin a new transaction
BEGIN TRANSACTION
--Make some changes to data
You can also abbreviate the word TRANSACTION to TRAN if you're a lazy typist like me.
--Begin a new transaction (the short way)
BEGIN TRAN
--Make some changes to data
It's possible to open multiple transactions within the same script and so it's useful to be able to name individual transactions in order to help identify them.
--Begin a new transaction with a name
BEGIN TRAN MyTransactionName
--Make some changes to data
You can also use a variable to set the name of a transaction, like so:
DECLARE @TranName VARCHAR(50)
SET @TranName = 'MyTransaction'
BEGIN TRAN @TranName
When you've started a transaction you must always explicitly end it in one of two ways. You can either commit the transaction, which saves the changes you have made, or you can rollback the transaction, which undoes the changes you have made.
To commit a transaction you use the COMMIT statement, as shown below:
--Start a new transaction
BEGIN TRAN
--Make some changes to data
--Save the changes you have made
COMMIT
You can be more specific when you commit a transaction. The code below shows several ways to commit a transaction:
--Various ways to commit a transaction
COMMIT
COMMIT TRAN
COMMIT TRANSACTION
COMMIT TRAN MyTransactionName
If you'd rather undo your changes you can use the ROLLBACK statement. Just as with the COMMIT statement you have a variety of ways to do this:
--Various ways to rollback a transaction
ROLLBACK
ROLLBACK TRAN
ROLLBACK TRANSACTION
ROLLBACK TRAN MyTransactionName
You could also replace the words TRAN or TRANSACTION with the word WORK in the above examples. The only difference between COMMIT/ROLLBACK TRANSACTION and COMMIT/ROLLBACK WORK is that you can't use a named transaction with the WORK keyword.
The next part of this series explains what happens when things go wrong within a transaction.
You can learn more about this topic on the following Wise Owl courses:
Kingsmoor House
Railway Street
GLOSSOP
SK13 2AA
Landmark Offices
99 Bishopsgate
LONDON
EC2M 3XD
Holiday Inn
25 Aytoun Street
MANCHESTER
M1 3AE
© Wise Owl Business Solutions Ltd 2025. All Rights Reserved.