如果需要实现事务。那么在数据库中实现事务,还是在应用程序中实现事务?分别适用什么样的场景呢? - 爱问答

(爱问答)

如果需要实现事务。那么在数据库中实现事务,还是在应用程序中实现事务?分别适用什么样的场景呢?

数据库应用系统中,如果需要实现事务。那么在数据库中实现事务,还是在应用程序中实现事务?分别适用什么样的场景呢?

事务处理是在针对数据库操作时一个重要环节,它可以保证执行多条记录的一致性,实现数据库中表与表之间的关联,同时提高了对数据操作的准确性、安全性。本文主要一起来学习在java程序中如何使用JDBC来实现数据间的事务处理。一、什么是事务处理事务处理就是当执行多个SQL指令时,如果因为某个原因使其中一条指令执行有错误,则取消先前执行过的所有指令。它的作用是保证各项操作的一致性和完整性。二、JDBC中的事务控制JDBC API中的JDBC事务是通过Connection对象进行控制的。Connection对象提供了两种事务模式:自动提交模式和手工提交模式。系统默认为自动提交模式,即,对数据库进行操作的每一条记录,都被看作是一项事务。操作成功后,系统会自动提交,否则自动取消事务。 如果想对多个SQL进行统一的事务处理,就必须先取消自动提交模式,通过使用Connection 的setAutoCommit(false) 方法来取消自动提交事务。Connection类中还提供了如下其他控制事务的方法:1)public boolean getAutoCommit():判断当前事务模式是否为自动提交,如果是则返回ture,否则返回false;2)public void commit():提交事务;3)public void rollback():回滚事务;注意:java中使用JDBC事务处理,一个JDBC不能跨越多个数据库而且需要判断当前使用的数据库是否支持事务。这时可以使用 DatabaseMedaData 的supportTranslations() 方法进行检查数据库是否支持事务处理,若返回 true 则说明支持事务处理,否则返回 false 。如使用mysql 的事务功能,就要求mysql里的表的类型为Innodb才支持事务控制处理,否则,在java程序中做了 commit 或 rollback ,但数据库中是不生效的。三、JDBC 事务处理基本流程实现事务处理的基本流程如下:1)判断当前使用的JDBC驱动程序和数据库是否支持事务处理;2)在支持事务处理的前提下,取消系统自动提交模式;3)添加需要进行的事务信息;4)将事务处理提交到数据库;5)在处理事务时,若某条信息发生错误,则执行事务回滚操作,并回滚到事务提交前的状态。四、事务处理的实例利用JDBC实现事务处理的实例,将4条SQL语句加在同一个事务里,当其中一条语句发生错误时,则执行事务回滚,取消所有的操作。所以在最后的运行结果中,并没有发现有数据更新。1、具体的代码如下:[java] view plaincopypackage chp07;import java.sql.Connection;import java.sql.DatabaseMetaData;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;public class java_Transa {// 数据库连接public static Connection getConnection() {Connection con = null;try {Class.forName("com.mysql.jdbc.Driver"); // 加载Mysql数据驱动con = DriverManager.getConnection("jdbc:mysql://localhost:3306/myuser", "root", "root"); // 创建数据连接} catch (Exception e) {System.out.println("数据库连接失败");}return con;}// 判断数据库是否支持事务public static boolean JudgeTransaction(Connection con) {try {// 获取数据库的元数据DatabaseMetaData md = con.getMetaData();// 获取事务处理支持况return md.supportsTransactions();} catch (SQLException e) {e.printStackTrace();}return false;}// 将一组SQL语句放在一个事务里执行,要么全部执行通过,要么全部不执行public static void StartTransaction(Connection con, String[] sqls) throws Exception {if (sqls == null) {return;}Statement sm = null;try {// 事务开始System.out.println("事务处理开始!");con.setAutoCommit(false); // 设置连接不自动提交,即用该连接进行的操作都不更新到数据库sm = con.createStatement(); // 创建Statement对象//依次执行传入的SQL语句for (int i = 0; i < sqls.length; i++) {sm.execute(sqls[i]);// 执行添加事物的语句}System.out.println("提交事务处理!");con.commit(); // 提交给数据库处理System.out.println("事务处理结束!");// 事务结束//捕获执行SQL语句组中的异常} catch (SQLException e) {try {System.out.println("事务执行失败,进行回滚! ");con.rollback(); // 若前面某条语句出现异常时,进行回滚,取消前面执行的所有操作} catch (SQLException e1) {e1.printStackTrace();}} finally {sm.close();}}// 查询表 staffpublic static void query_student() throws Exception {Connection conect = getConnection(); // 获取连接System.out.println("执行事物处理后,表 staff 的全部记录为: ");try {String sql = "select * from staff"; // 查询数据的sql语句Statement st = (Statement) conect.createStatement(); // 创建Statement对象ResultSet rs = st.executeQuery(sql); // 执行SQL语句并返回查询数据的结果集//打印输出查询结果while (rs.next()) { // 判断是否还有下一个数据// 根据字段名获取相应的值String name = charset(rs.getString("name"));int age = rs.getInt("age");String sex = charset(rs.getString("sex"));String depart = charset(rs.getString("depart"));String address = charset(rs.getString("address"));int worklen = rs.getInt("worklen");int wage = rs.getInt("wage");System.out.println(name + " " + age + " " + sex + " "+ address + " " + depart + " " + worklen + " " + wage);}System.out.println();} catch (SQLException e) {System.out.println("查询数据失败");}}// 字符集的设定,解决中文乱码public static String charset(String str) throws Exception {String newStr = new String(str.getBytes("ISO8859-1"), "UTF-8");return newStr;}public static void main(String[] args) throws Exception {String[] arry = new String[4]; // 定义一组事物处理语句arry[0] = "delete from staff where name='Serein'"; //删除staff表格中 name 字段值为 "Serein" 的员工记录arry[1] = "UPDATE staff SET address='Shenzhen' where name=lili";// 执行这条语句会引起错误,因为表 staff 中name='lili'不存在arry[2] = "INSERT INTO student (name,age,sex,address,depart,worklen,wage)" //SQL插入记录语句+ "values ('Allen',19,'M','Beijing','Engine',4,4800)";arry[3] = "select * from staff"; //SQL查询表 staff 语句Connection con = null;try {con = getConnection(); // 获得数据库连接boolean judge = JudgeTransaction(con); // 判断是否支持批处理System.out.print("支持事务处理吗? ");System.out.println(judge ? "支持" : "不支持");if (judge) {StartTransaction(con, arry); // 如果支持则开始执行事务}} catch (Exception e) {e.printStackTrace();} finally {con.close(); // 关闭数据库连接}query_student();}}说明:该java程序中数据库操作涉及的数据库为 “myuser ” ,并使用其中的 “staff” 表格,也就是我之前的文章《JDBC连接MySQL数据库及示例》里所创建的数据库和表。如果需要跟着去实现并运行这个例子的话,可以前去参考创建,或者根据你自己的数据库况去修改其中有关连接MySQL的代码以及SQL语句。附上程序运行前的“staff”表格中的数据:注意观察里面的第三条记录,即 name 字段值为“Seren”的记录。即将运行的 java 程序的第113代码中的 SQL 语句表示要删除该条记录,但是由于后面的事务出错,所以全部的事务不执行,并回滚,所以最后的结果是name为“Serein”这条记录依旧存在于数据表中。

DML操作需要用到事务。就是说执行数据库操作的SQL,包括insert,delete,update,select(插入、删除、修改、检索)。其中对于检索,如果不需要排他的话,可以不用加事务锁。

相关标签:数据库

下一篇:请问一下怎样可以打出这个符号

上一篇:谷歌检查查看图片图片Nothingtopreview是怎么回事

热门标签:
excel 网盘 破解 word dll
最新更新:
微软重新评估新的Outlook的使用时机 联想推出搭载联发科Helio G80芯片组的Tab M9平板 英特尔创新大赛时间确定! 微软Edge浏览器在稳定渠道中推出Workspaces功能 英伟达RTX4060TiGPU推出MaxSun动漫主题! 谷歌地图为用户提供了街景服务! GameSir 在T4 Kaleid中推出了一款出色的控制器! 微软开始在Windows 11 中测试其画图应用程序的新深色模式! LG电子推出全球首款无线OLED电视 英伟达人工智能芯片崭露头角! Steam Deck可以玩什么游戏-Steam Deck价格限时优惠 雷蛇推出CobraPro鼠标 Kindle电子阅读器可以访问谷歌商店吗 Windows10如何加入组策略 window10图片查看器怎么没有了?