什么时候使用事务?如果实际的业务中,需要将一条数据同时存放到两张表中, 并且要求两张表中的数据同步,那么此时就需要使用事务管理机制,保证数据同步。如果出现错误情况,比如表一插入数据成功,表二插入数据失败,那么就回滚,终止数据持久化操作。金融
什么时候使用事务?
如果实际的业务中,需要将一条数据同时存放到两张表中, 并且要求两张表中的数据同步,那么此时就需要使用事务管理机制,保证数据同步。如果出现错误情况,比如表一插入数据成功,表二插入数据失败,那么就回滚,终止数据持久化操作。
金融行业的软件开发严格重视事务处理,比如我们常见的转账操作,一方的账户金额减少,对应的是另一方的账户金额增加,这个过程需要使用到事务机制,不然转账不能成功。
以JDBC处理事务为例:
public static void main(String[] args) throws sqlException, ClassNotFoundException {
Class.forName("com.Mysql.jdbc.Driver");
String url = "jdbc:mysql://localhost:3306/user";
String user = "root";
String passWord = "123456";
Connection con = (Connection) DriverManager.getConnection(url, user, password);
try {
//取消自动提交
//如果设成false,那就是JDBC不自动提交,需要手动的使用commit或者rollback来进行提交或者回滚数据.
con.setAutoCommit(false);
Statement stmt = (Statement) con.createStatement();
//进行数据插入
String sql = "insert into users(email,password) values('" + "jack@163.com" + "','" + "jack" + "');";
boolean flag = stmt.execute(sql);
System.out.println(flag);
//人为制造一个错误,结果就是数据库并没有插入这条数据,也就是数据发生了回滚
//异常被捕获之后,就不在执行下面的语句,而是执行catch中的语句
//如果没有异常,数据就会被提交到数据库
System.out.println(1/0);
//手动提交
con.commit();
} catch (Exception e) {
//如果发生错误,就回滚
con.rollback();
} finally {
con.close();
}
}
相关文章教程推荐:java入门教程
--结束END--
本文标题: java中什么时候使用事务
本文链接: https://www.lsjlt.com/news/2648.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-04-01
2024-04-03
2024-04-03
2024-01-21
2024-01-21
2024-01-21
2024-01-21
2023-12-23
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0