Java 的事务

1 java事务有两种事务。第一种是JDBC事务。第二种是JTA事务。

2 第一种事务:JDBC事务。是通过setAutoCommit()来设置是否自动提交。

如:Context context=new InitialContext();

DataSource dataSource=(DataSource)context.lookup("test");

Connection connection=dataSource.getConnection();

Statement statement=connection.createStatement();

try {

connection.setAutoCommit(false);--设置不自动提交statement.executeUpdate("insert into demo1(NM,NAME,PASSWORD) values('1','11','111')");statement.executeUpdate("insert into demo1(NM,NAME,PASSWORD) values('2','22','222')");statement.executeUpdate("delete from demo1 where NM='1'");

connection.commit();--事务提交

connection.setAutoCommit(true);--改成自动提交

System.out.println("事务动作已全部执行,被提交");

} catch (RuntimeException e) {

// TODO Auto-generated catch block

System.out.println("事务进行失败,正在回滚中。。。");

e.printStackTrace();

connection.rollback();

}

JDBC事务,就是先设置成不自动提交,然后执行操作更新数据库操作。最后再通过commit一起提交。在最后改成自动提交即可。这就是JDBC事务。

3第二种事务:JTA事务。是通过Transaction来控制的。

如:Context context=new InitialContext();

DataSource dataSource=(DataSource)context.lookup("test");

Connection connection=dataSource.getConnection();

Transaction transaction=this.getSessionFactory().openSession().beginTransaction();--记住一定要通过openSession来得到session,然后通过beginTransaction来初始化Transaction

Statement statement=connection.createStatement();

try {transaction.begin();--通过JTA事务开始

statement.executeUpdate("insert into demo1(NM,NAME,PASSWORD) values('334','33','333')");

statement.executeUpdate("insert into demo1(NM,NAME,PASSWORD) values('444','44','444')");

statement.executeUpdate("delete from demo1 where NM='33'");

transaction.commit();--通过JTA事务提交,即结束事务

} catch (RuntimeException e) {

// TODO Auto-generated catch block

transaction.rollback();--如果执行事务失败,则回滚

e.printStackTrace();

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Binggo man

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值