SQLServer事务的傻瓜讲解
在本文之前我读过多篇关于事务的文章,大都说的比较深奥,可能让新手也难以理解。 在此我们用非常简单的例子讲解一下事务的应用吧。 ?第一:我们先创建一个临时表,填写一些数据。 ? 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 开始事务 DELETE FROM #tab ? 现在我们是执行了事务之后删除的#tab( 一定要先执行事务,不然你就会把数据直接给KO掉了。) 注 : 假如我们上一步我们执行错误,需要回复数据。我们需要执行一下 --回滚 ROLLBACK 我们的数据又回来了。 ? 注 : 假如上一步我们执行正确了, 你也不要忘记执行下面这句 (这句不执行的话会造成用户死锁。) -- 执行 COMMIT 理解很简单吧。事务就是 先执行BEGIN TRANSACTION?? 错误执行 ROLLBACK? 正确执行 COMMIT?? 所以我们会经常用到这种格式的事务。 BEGIN TRANSACTION??? -- 开始事务 事务的机制很复杂,但在使用时我们只需要理解上面的顺序即可。 由此我们可以进行程序细颗粒事务回滚的分析,在需要的地方正确的使用事务。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |