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();
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值