在本文之前我读过多篇关于事务的文章,大都说的比较深奥,可能让新手也难以理解。 在此我们用非常简单的例子讲解一下事务的应用吧。
第一:我们先创建一个临时表,填写一些数据。
CREATE TABLE #tab (id INT,country NVARCHAR(10),popu INT ) INSERT INTO #tab VALUES (1,'中国','600') INSERT INTO #tab VALUES (2,'美国','100') INSERT INTO #tab VALUES (3,'加拿大','100') INSERT INTO #tab VALUES (4,'英国','200') INSERT INTO #tab VALUES (5,'法国','300') INSERT INTO #tab VALUES (6,'日本','250') INSERT INTO #tab VALUES (7,'德国','200') INSERT INTO #tab VALUES (8,'墨西哥','50') INSERT INTO #tab VALUES (9,'印度','250')
以上我们就得到了一个临时表数据。
第二: 写几句常用事务语句。
BEGIN TRANSACTION COMMIT ROLLBACK
好需要的数据和语句我们准备好了。 仔细看下面操作:
-- 我们下执行一下sql 开始事务
BEGIN TRANSACTION
然后我们直接删除#tab
DELETE FROM #tab
现在肯定查询不到数据了。
现在我们是执行了事务之后删除的#tab( 一定要先执行事务,不然你就会把数据直接给KO掉了。)
注 : 假如我们上一步我们执行错误,需要回复数据。我们需要执行一下
--回滚
ROLLBACK
我们的数据又回来了。
注 : 假如上一步我们执行正确了, 你也不要忘记执行下面这句 (这句不执行的话会造成用户死锁。)
-- 执行 COMMIT
理解很简单吧。事务就是 先执行BEGIN TRANSACTION 错误执行 ROLLBACK 正确执行 COMMIT 所以我们会经常用到这种格式的事务。
BEGIN TRANSACTION -- 开始事务
BEGIN TRY -- 捕捉异常
DELETE FROM #tab
COMMIT -- 无异常执行
END TRY
BEGIN CATCH
ROLLBACK -- 发现异常 回滚
END CATCH
事务的机制很复杂,但在使用时我们只需要理解上面的顺序即可。 由此我们可以进行程序细颗粒事务回滚的分析,在需要的地方正确的使用事务。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。