SQLServer事务的傻瓜讲解
来源:互联网 发布:韶关网络问政门户网站 编辑:程序博客网 时间:2024/04/19 12:20
在本文之前我读过多篇关于事务的文章,大都说的比较深奥,可能让新手也难以理解。 在此我们用非常简单的例子讲解一下事务的应用吧。
第一:我们先创建一个临时表,填写一些数据。
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
事务的机制很复杂,但在使用时我们只需要理解上面的顺序即可。 由此我们可以进行程序细颗粒事务回滚的分析,在需要的地方正确的使用事务。
- SQLServer事务的傻瓜讲解
- sqlserver事务的用法
- sqlserver事务的用法
- sqlserver事务的用法
- sqlserver事务的用法
- SQLServer--事务的创建
- SQLServer -- 事务的应用
- 事务的讲解
- vi 命令傻瓜讲解
- vi 命令傻瓜讲解
- SqlServer 存储过程的事务
- SQLServer事务的隔离级别
- SQLServer事务的隔离级别
- SQLServer事务的隔离级别
- SQLServer事务的隔离级别
- SQLServer事务的隔离级别
- SQLServer事务的隔离级别
- SQLServer事务的隔离级别
- 写字 修改脉冲数
- SSH原理与运用(一):远程登录
- eclipse错误 -- Unsupported content type in editor.
- django model group by day
- 关于CSS3圆角
- SQLServer事务的傻瓜讲解
- cts测试之CtsOsTestCases
- TCP/IP 深刻理解
- 实现C语言高效编程的四大秘技
- .Spring定时器在SSH框架中的应用
- QT__QLabel__操作
- 利用ArcGIS水文分析工具提取河网(转)
- Activity之间的相互调用与传递参数
- printf特效