Chinaunix首页 | 论坛 | 博客
  • 博客访问: 977665
  • 博文数量: 152
  • 博客积分: 4937
  • 博客等级: 上校
  • 技术积分: 1662
  • 用 户 组: 普通用户
  • 注册时间: 2007-10-05 16:55
文章分类

全部博文(152)

文章存档

2013年(12)

2012年(6)

2011年(58)

2010年(43)

2009年(1)

2008年(15)

2007年(17)

我的朋友

分类: Java

2013-04-18 16:20:42

iBatis中使用事务

先复习一下事务的特点:ACID

Atomicity: 原子性
Consistency: 一致性
Isolation: 隔离性
Durability: 耐久性

iBatis中的事务分为:
Automatic Transaction
Local Transaction
Global Transaction
Custom Transaction

Automatic Transaction:

默认情况下iBatis认为每个statement都是一个事务

比如
public void runStatementsUsingAutomaticTransactions()    
{
     SqlMapClient sqlMapClient =
       SqlMapClientConfig.getSqlMapClient();
      Person p = (Person)
         sqlMapClient.queryForObject("getPerson",  // 第一个事务
                                     new Integer(9));
      p.setLastName("Smith");
      sqlMapClient.update("updatePerson", p); //第二个事务
}

Local Transaction:

如果你想将几个statement作为一个事务来处理,可以用
startTransaction,endTransaction来划分事务

比如
public void runStatementsUsingLocalTransactions() {
SqlMapClient sqlMapClient =
    SqlMapClientConfig.getSqlMapClient();

try {
      sqlMapClient.startTransaction();
//事务开始
      Person p =
       (Person)sqlMapClient.queryForObject
                       ("getPerson", new Integer(9));

      p.setLastName("Smith");
      sqlMapClient.update("updatePerson", p);

      Department d =
       (Department)sqlMapClient.queryForObject      
                       ("getDept", new Integer(3));

      p.setDepartment(d);
      sqlMapClient.update("updatePersonDept", p);

      sqlMapClient.commitTransaction();
//提交事务,从开始到这里是一个事务

} finally {
        sqlMapClient.endTransaction();
//事务结束
}
}

阅读(1611) | 评论(0) | 转发(0) |
0

上一篇:iBATIS事务处理浅析

下一篇:没有了

给主人留下些什么吧!~~