关于事务的隔离性

例如:统计定单系统中事务活动   如下  
  1.事务T1打印定单表中的记录  
  2.T2向定单表插入了新的定单,T2提交  
  3.事务T1统计定单表中的的记录总数,T1提交  
    因为事务T2在T1结束前向定单表中插入了新的记录,导致事务T1打印的定单记录数量和T1统计的定单数量不一致.  
      产生并发异常问题的主要原因是并发操作破坏了事务的隔离性,导致数据不一致.如何使一个事务不受到其它事务的干扰,保证数据一致性???  
  完整的例子代码,在线等待,谢谢大家的关心:)

 如何锁一个表的某一行  
   
   
  A   连接中执行  
   
  SET   TRANSACTION   ISOLATION   LEVEL   REPEATABLE   READ  
   
  begin   tran  
   
  select   *   from   tablename   with   (rowlock)   where   id=3  
   
  waitfor   delay   "00:00:05"  
   
  commit   tran  
   
  B连接中如果执行  
   
  update   tablename   set   colname="10"   where   id=3   --则要等待5秒  
   
  update   tablename   set   colname="10"   where   id<>3   --可立即执行  
   
   
   
  3.   锁定数据库的一个表  
   
  SELECT   *   FROM   table   WITH   (HOLDLOCK)    
   
   
  注意:   锁定数据库的一个表的区别  
   
  SELECT   *   FROM   table   WITH   (HOLDLOCK)    
  其他事务可以读取表,但不能更新删除  
   
  SELECT   *   FROM   table   WITH   (TABLOCKX)    
  其他事务不能读取表,更新和删除  
   
  SELECT   语句中“加锁选项”的功能说明  
  SQL   Server提供了强大而完备的锁机制来帮助实现数据库系统的并发性和高性能。用户既能使用SQL   Server的缺省设置也可以在select   语句中使用“加锁选项”来实现预期的效果。   本文介绍了SELECT语句中的各项“加锁选项”以及相应的功能说明。  
  功能说明:     
  NOLOCK(不加锁)    
  此选项被选中时,SQL   Server   在读取或修改数据时不加任何锁。   在这种情况下,用户有可能读取到未完成事务(Uncommited   Transaction)或回滚(Roll   Back)中的数据,   即所谓的“脏数据”。    
   
  HOLDLOCK(保持锁)    
  此选项被选中时,SQL   Server   会将此共享锁保持至整个事务结束,而不会在途中释放。    
   
  UPDLOCK(修改锁)    
  此选项被选中时,SQL   Server   在读取数据时使用修改锁来代替共享锁,并将此锁保持至整个事务或命令结束。使用此选项能够保证多个进程能同时读取数据但只有该进程能修改数据。    
   
  TABLOCK(表锁)    
  此选项被选中时,SQL   Server   将在整个表上置共享锁直至该命令结束。   这个选项保证其他进程只能读取而不能修改数据。    
   
  PAGLOCK(页锁)    
  此选项为默认选项,   当被选中时,SQL   Server   使用共享页锁。    
   
  TABLOCKX(排它表锁)    
  此选项被选中时,SQL   Server   将在整个表上置排它锁直至该命令或事务结束。这将防止其他进程读取或修改表中的数据。 

 

这样的锁是没有问题,但这样锁住后,其他的用户要操作的话,都只能等待(堵塞其他用户进程,严重的产生死锁)  
   
  --示例  
  begin   tran     --开始事务  
  --查询出要打印的数据  
  select   *   from   表   with(TABLOCKX)     --加锁,阻止其他用户读取或操作表  
  --这里进行你打印  
  rollback   tran  
   
   
  drop   table   tb

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值