首页 > 编程语言 > 详细

Java中为什么使用事务?什么时候使用事务?如何使用事务?

时间:2019-06-30 17:03:12      阅读:206      评论:0      收藏:0      [点我收藏+]

一、为什么使用事务?

  直白一点说,就是为了给自己后悔药吃。

  因为对于数据库的操作,是持久性的,所以我需要谨慎对待,如果没有满足条件,对数据库的操作就会失效,也就是给自己一次反悔的机会,泼出去的水还可以收回来

二、什么时候使用事务?

  场景一:如果实际的业务中,需要将一条数据同事存放到两张表中, 并且要求两张表中的数据同步,那么此时就需要使用事务管理机制,保证数据同步。如果出现错误情况,比如表一插入数据成功,表二插入数据失败,那么就回滚,终止数据持久化操作。

  场景二:金融行业的软件开发严格重视事务处理,比如我们常见的转账操作,一方的账户金额减少,对应的是另一方的账户金额增加,这个过程需要使用到事务机制,不然转账不能成功

三、如何使用事务?

(一)JDBC处理事务

  

 1 public static void main(String[] args) throws SQLException, ClassNotFoundException {
 2         Class.forName("com.mysql.jdbc.Driver");
 3         String url = "jdbc:mysql://localhost:3306/user";
 4         String user = "root";
 5         String password = "123456";
 6         Connection con = (Connection) DriverManager.getConnection(url, user, password);
 7         try {
 8             //取消自动提交
 9             //如果设成false,那就是JDBC不自动提交,需要手动的使用commit或者rollback来进行提交或者回滚数据. 
10             con.setAutoCommit(false);
11             Statement stmt = (Statement) con.createStatement();
12             //进行数据插入
13             String sql = "insert into users(email,password) values(‘" + "jack@163.com" + "‘,‘" + "jack" + "‘);";
14             boolean flag = stmt.execute(sql);
15             System.out.println(flag);
16             //人为制造一个错误,结果就是数据库并没有插入这条数据,也就是数据发生了回滚
17             //异常被捕获之后,就不在执行下面的语句,而是执行catch中的语句
18             //如果没有异常,数据就会被提交到数据库
19             System.out.println(1/0);
20             //手动提交
21             con.commit();
22         } catch (Exception e) {
23             //如果发生错误,就回滚
24             con.rollback();
25         } finally {
26             con.close();
27         }
28     }

 

(二)Spring处理事务

Java中为什么使用事务?什么时候使用事务?如何使用事务?

原文:https://www.cnblogs.com/codeXi/p/11110143.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!