JAVA JDBC 数据库的一点记录:事务

JAVA JDBC 数据库的一点记录:事务



import java.sql.*; public class TestBatch { public static void main(String[] args) throws SQLException { Connection conn = null; Statement stmt = null; PreparedStatement pstmt = null; try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection ("jdbc:mysql://localhost/test","root","ZHEN"); conn.setAutoCommit(false); ////事务1 transaction stmt = conn.createStatement(); //执行静态 SQL 语句并返回它所生成结果的对象。 stmt.addBatch("INSERT INTO student VALUES(30,'ddd',12,'ii')"); stmt.addBatch("INSERT INTO student VALUES(31,'ddd',12,'ii')"); stmt.addBatch("INSERT INTO student VALUES(32,'ddd',12,'ii')"); stmt.addBatch("INSERT INTO student VALUES(33,'ddd',12,'ii')"); stmt.executeBatch(); /////事务2 pstmt = conn.prepareStatement("INSERT INTO student VALUES(?,?,?,?)"); pstmt.setInt(1, 40); pstmt.setString(2,"qq"); pstmt.setInt(3,5); pstmt.setString(4,"ww"); pstmt.addBatch(); pstmt.setInt(1, 41); pstmt.setString(2,"qq"); pstmt.setInt(3,5); pstmt.setString(4,"ww"); pstmt.addBatch(); pstmt.executeBatch(); /// conn.commit(); //若事务1 和事务2必需要同时完成 或 同时不完成,不能存在只有其中一个被完成的情况,则要用transaction }catch (ClassNotFoundException e1) { e1.printStackTrace(); }catch (SQLException e) { e.printStackTrace(); conn.rollback(); //若事务处理失则,必需回滚 conn.setAutoCommit(true); }finally{ stmt.close(); pstmt.close(); conn.close(); } } }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值