在java代码中实现对数据库事务的控制
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了在java代码中实现对数据库事务的控制,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3041字,纯文字阅读大概需要5分钟。
内容图文
![在java代码中实现对数据库事务的控制](/upload/InfoBanner/zyjiaocheng/861/340b2f96e4de460bb6dd2b5eb44b1a9b.jpg)
默认情况下,数据库连接处于自动提交模式。每个sql语句一旦被执行便提交给数据库。一旦命令提交,就无法对其进行回滚操作。在使用事务时需要关闭这个默认值。
package preparedStament; import java.lang.reflect.Field; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.ResultSetMetaData; import org.junit.Test; import bean.User_cursetom; import JDBCutils.JdbcUtils; /** * @author ztr * @version 创建时间:2021年4月1日 下午8:41:04 * 类说明 */ /** */ public class TransactionTest { /** * 考虑数据库的事务 * * @param clazz * @param sql * @param args * @return */ public <T> T GetInstance(Connection connection, Class<T> clazz, String sql, Object... args) { PreparedStatement prepareStatement = null; // 获取结果集 ResultSet resultSet = null; try { prepareStatement = connection.prepareStatement(sql); for (int i = 0; i < args.length; i++) { prepareStatement.setObject(i + 1, args[i]); } resultSet = prepareStatement.executeQuery(); // 获取元数据 ResultSetMetaData metaData = resultSet.getMetaData(); // 通过metaData获取结果集中的列数 int columnCount = metaData.getColumnCount(); if (resultSet.next()) { T newInstance = clazz.newInstance(); for (int i = 0; i < columnCount; i++) { // 获取列值 Object columnValue = resultSet.getObject(i + 1); // 获取每列的列名 String columnName = metaData.getColumnName(i + 1); // 利用反射 Field field = clazz.getDeclaredField(columnName); // 考虑该属性是否为私有 field.setAccessible(true); field.set(newInstance, columnValue); } return newInstance; } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } finally { // 关闭资源 JdbcUtils.closeResource1(null, prepareStatement, resultSet); } return null; } public void update(Connection connection, String sql, Object... args) { // 获取数据连接 // 预编译sql语句返回preparedStatement PreparedStatement prepareStatement = null; try { prepareStatement = connection.prepareStatement(sql); // 填充占位符 // prepareStatement.setObject的下标从1开始 for (int i = 0; i < args.length; i++) { prepareStatement.setObject(i + 1, args[i]); } // 执行 prepareStatement.execute(); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } finally { // 资源的关闭 JdbcUtils.closeResource(null, prepareStatement); } } @Test public void test1() throws Exception { Connection connection = JdbcUtils.getConnection(); // 获取事务的隔离级别 System.out.println(connection.getTransactionIsolation()); // 取消事务的自动提交 // 设置事务的隔离级别 connection .setTransactionIsolation(Connection.TRANSACTION_READ_COMMITTED); connection.setAutoCommit(false); String sql = "select id,balance from user_cursetom where id = ?"; User_cursetom getInstance = GetInstance(connection, User_cursetom.class, sql, 1); System.out.println(getInstance); } @Test public void test2() throws Exception { Connection connection = JdbcUtils.getConnection(); // 取消事务的自动提交 connection.setAutoCommit(false); String sql = "update user_cursetom balance set balance = 1000 where id = ?"; update(connection, sql, 1); Thread.sleep(15000); System.out.println("修改结束"); connection.rollback(); connection.commit(); } }
内容总结
以上是互联网集市为您收集整理的在java代码中实现对数据库事务的控制全部内容,希望文章能够帮你解决在java代码中实现对数据库事务的控制所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。