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();
		}
	}

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值