Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1241479
  • 博文数量: 510
  • 博客积分: 20296
  • 博客等级: 上将
  • 技术积分: 4680
  • 用 户 组: 普通用户
  • 注册时间: 2007-10-30 03:58
文章存档

2011年(13)

2010年(92)

2009年(242)

2008年(163)

我的朋友

分类: 数据库开发技术

2009-10-20 22:51:34

一、事务概念
    事务是一种机制、是一种操作序列,它包含了一组数据库操作命令,这组命令要么全部执行,要么全部不执行。因此事务是一个不可分割的工作逻辑单元。在数据库系统上执行并发操作时事务是作为最小的控制单元来使用的。这特别适用于多用户同时操作的数据通信系统。例如:订票、银行、保险公司以及证券交易系统等。
 
二、事务属性
事务4大属性:
1   原子性(Atomicity):事务是一个完整的操作。
2   一致性(Consistency):当事务完成时,数据必须处于一致状态。
3   隔离性(Isolation):对数据进行修改的所有并发事务是彼此隔离的。
4   持久性(Durability):事务完成后,它对于系统的影响是永久性的。
 
三、创建事务
T-SQL中管理事务的语句:
1 开始事务: begin transaction
2 提交事务:commit transaction
3 回滚事务: rollback transaction
 
事务分类:
1 显式事务:用begin transaction明确指定事务的开始。
2 隐性事务:打开隐性事务:set implicit_transactions on,当以隐性事务模式操作时,SQL Servler将在提交或回滚事务后自动启动新事务。无法描述事务的开始,只需要提交或回滚事务。
3 自动提交事务:SQL Server的默认模式,它将每条单独的T-SQL语句视为一个事务。如果成功执行,则自动提交,否则回滚。
 
示例:张三转800元到李四帐户上。
  1. use stuDB
  2. go
  3. --创建帐户表bank--

  4. if exists(select* from sysobjects where name='bank')
  5.     drop table bank
  6. create table bank
  7. (
  8.     customerName char(10), --顾客姓名

  9.     currentMoney money --当前余额

  10. )
  11. go
  12. /**//*--添加约束,帐户不能少于元--*/
  13. alter table bank add
  14.         constraint CK_currentMoney check(currentMoney>=1)
  15. /**//*--插入测试数据--*/
  16. insert into bank(customerName,currentMoney)
  17. select '张三',1000 union
  18. select '李四',1
  19. select * from bank
  20. go
  21. /**//*--使用事务--*/
  22. use stuDB
  23. go
  24. --恢复原来的数据

  25. --update bank set currentMoney=currentMoney-1000 where customerName='李'

  26. set nocount on --不显示受影响的行数

  27. print '查看转帐事务前的余额'
  28. select * from bank
  29. go
  30. /**//*--开始事务--*/
  31. begin transaction
  32. declare @errorSum int --定义变量,用于累计事务执行过程中的错误

  33. /**//*--转帐--*/
  34. update bank set currentMoney=currentMoney-800 where customerName='张三'
  35. set @errorSum=@errorSum+@@error --累计是否有错误

  36. update bank set currentMoney=currentMoney+800 where customerName='李四'
  37. set @errorSum=@errorSum+@@error --累计是否有错误

  38. print '查看转帐事务过程中的余额'
  39. select * from bank
  40. /**//*--根据是否有错误,确定事务是提交还是回滚--*/
  41. if @errorSum>0
  42.     begin
  43.         print '交易失败,回滚事务.'
  44.         rollback transaction
  45.     end
  46. else
  47.     begin
  48.         print '交易成功,提交事务,写入硬盘,永久保存!'
  49.         commit transaction
  50.     end
  51. go
  52. print '查看转帐后的余额'
  53. select * from bank
  54. go

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/zerolsy/archive/2008/02/26/2123637.aspx

阅读(706) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~