在存储过程中编写正确的事务处理代码

SET
XACT_ABORT

指定当 Transact-SQL
语句产生运行时错误时,Microsoft® SQL Server™ 是否自动回滚当前事务。

语法

SET XACT_ABORT { ON | OFF }

注释

当 SET XACT_ABORT 为 ON 时,如果
Transact-SQL 语句产生运行时错误,整个事务将终止并回滚。为 OFF 时,只回滚产生错误的 Transact-SQL
语句,而事务将继续进行处理。编译错误(如语法错误)不受 SET XACT_ABORT 的影响。

对于大多数 OLE DB 提供程序(包括 SQL
Server),隐性或显式事务中的数据修改语句必须将 XACT_ABORT 设置为
ON。唯一不需要该选项的情况是提供程序支持嵌套事务时。有关更多信息,请参见分布式查询分布式事务

SET XACT_ABORT
的设置是在执行或运行时设置,而不是在分析时设置。

1.默认为SET XACT_ABORT OFF 即遇到错误时回滚(真是晕,这不叫回滚,遇到错误当然不能执行了)所以干脆说默认回滚不起作用。
2.SET XACT_ABORT OFF
。。。
COMMIT TRAN
这时才是所谓真正的事务,遇到任何错误事务回滚
3.SET XACT_ABORT OFF
。。。
这时遇到错误时事务回滚,错误前的操作正常

另@@IDENTITY
系统产销
==============================
理解 @@IDENTITY

@@IDENTITY 返回最后一个插入 IDENTITY 的值,这些操作包括:INSERT, SELECT
INTO,或者 bulk copy。如果在给没有 IDENTITY 列的其他表插入记录,系统将其置为 null。如果有多行记录插入到 IDENTITY
表中,@@IDENTITY 表示最后一个产生的值。如果触发了某个触发器,并且这个触发器执行向另一个带有 IDENTITY 列的表的插入操作,@@IDENTITY
将返回这个由触发器产生的值。如果这个触发器插入的表中不包含 IDENTITY 列,那么 @@IDENTITY 将为
null。如果插入操作失败,@@IDENTITY 值依然会增加,所以 IDENTITY 不保证数据的连续性。
一、准备工作:

1、首先我们创建测试数据库:

 create  database demo

2、创建数据表和测试数据:(这里注意外键控制)

 use demo
  CREATE  TABLE student
 (    
         stuid  int  NOT  NULL  PRIMARY  KEY,
         stuname  varchar( 50)
 )
  CREATE  TABLE score 
 (
         stuid  int  NOT  NULL  REFERENCES student(stuid),
         score  int
 )
  GO
 
  INSERT  INTO student  VALUES ( 101, ' zhangsan '
  INSERT  INTO student  VALUES ( 102, ' wangwu '
  INSERT  INTO student  VALUES ( 103, ' lishi '
  INSERT  INTO student  VALUES ( 104, ' maliu '
 
  GO

二、各种用法及输出结果:

1、语句1:

  use demo
 
  -- Invoking a run-time error
  SET XACT_ABORT  OFF
  BEGIN  TRAN
      INSERT  INTO score   VALUES ( 101, 90)
      INSERT  INTO score  VALUES ( 102, 78
     INSERT  INTO score  VALUES ( 107, 76)  
      INSERT  INTO score  VALUES ( 103, 81
      INSERT  INTO score  VALUES ( 104, 65
  COMMIT  TRAN
  go

结果1:只回滚错误行,语句还继续执行。

 -- select * from score
  101     90
  102     78
  103     81
  104     65

2、语句2:

  use demo
 
 --事务回滚
 SET XACT_ABORT on
 BEGIN TRAN
     INSERT INTO score  VALUES (101,90)
     INSERT INTO score VALUES (102,78
     INSERT INTO score VALUES (107,76)  
     INSERT INTO score VALUES (103,81
     INSERT INTO score VALUES (104,65
 COMMIT TRAN
 go

结果2:事务终止并全部回滚,结果为空。

 -- select * from score

3、语句3: 

 use demo
 
  -- 事务在错误行终止,错误行回滚,错误行之前的不回滚
  SET XACT_ABORT  on
  BEGIN
  INSERT  INTO score   VALUES ( 101, 90)
      INSERT  INTO score  VALUES ( 102, 78
      INSERT  INTO score  VALUES ( 107, 76)  
      INSERT  INTO score  VALUES ( 103, 81
      INSERT  INTO score  VALUES ( 104, 65
  END
  go

结果3:出现这种是因为系统把每个insert语句都看成是单独的事务,所以错误行以前的是不回滚的。

 -- select * from score
  101     90
  102     78

 

原文出处: http://blog.sina.com.cn/s/blog_4c81e6230100sq6q.html

转载于:https://www.cnblogs.com/linyechengwei/archive/2011/10/09/2203954.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Redis(Remote Dictionary Server)是一种开源的缓存数据库,它是用C语言编写的。在项目,我们可以用Java代码编写来使用Redis来实现数据的缓存和快速访问。 首先,我们需要在项目引入Redis的Java客户端库,例如Jedis或Lettuce。然后,我们可以通过以下代码示例来展示Redis在项目的应用。 1. 连接Redis服务器: ``` Jedis jedis = new Jedis("localhost"); // 如果Redis在不同的主机上,需要指定主机的IP地址或域名 ``` 2. 存储数据: ``` jedis.set("key", "value"); ``` 3. 获取数据: ``` String value = jedis.get("key"); ``` 4. 设置过期时间: ``` jedis.expire("key", 60); // 设置key的过期时间为60秒 ``` 5. 删除数据: ``` jedis.del("key"); ``` 6. 使用哈希表存储和获取数据: ``` jedis.hset("hash", "field", "value"); String fieldValue = jedis.hget("hash", "field"); ``` 7. 发布和订阅消息: ``` jedis.subscribe(new JedisPubSub() { @Override public void onMessage(String channel, String message) { // 处理接收到的消息 } }, "channel"); jedis.publish("channel", "message"); ``` 上述代码只是Redis在项目的一些简单应用示例,实际应用还有更多的功能和用法,例如使用事务、批量操作、分布式锁等。 总之,Redis在项目的应用可以提供高速的缓存访问和数据存储,能够有效提升系统性能和响应速度。使用Java代码编写,能够更加灵活地操作和管理Redis数据库

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值