JDBC事务(一)

 

package cn.sasa.tran01;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;

public class testJDBCTran {

    public static void main(String[] args) {
        Connection conn = null;
        PreparedStatement pstate = null;
        PreparedStatement pstate2 = null;
        try {
            //mysql的事务默认是自动执行的
            
            //注册驱动
            Class.forName("com.mysql.jdbc.Driver");
            
            //获得连接对象
            conn = DriverManager.getConnection("jdbc:mysql://192.168.0.207:3306/mydb", "root", "Console.Write21");
            
            //设置手动执行事务
            conn.setAutoCommit(false);
            
            //获得执行对象
            String sql = "insert into account (name,money) values ('aaaaaaaaaaaaaaaaaaa',200)";
            pstate = conn.prepareStatement(sql);
            //执行
            int rs = pstate.executeUpdate();
            
            String sql2 = "insert into account (name,money) values ('bb',300)";
            pstate2 = conn.prepareStatement(sql2);
            int rs2 = pstate2.executeUpdate();
            
            if(rs>0&&rs2>0) {
                conn.commit();//提交事务
                System.out.println("ok");
            }else {
                conn.rollback();//回滚事务
                System.out.println("-1");
            }
            
        }catch(Exception e) {
            try {
                conn.rollback();
                System.out.println("-2");
            } catch (SQLException e1) {
                e1.printStackTrace();
            }//回滚事务
        }finally {
            try {
                if(pstate !=null) pstate.close();
                if(pstate2 !=null) pstate2.close();
                if(conn !=null) conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }

}

 

posted @ 2019-04-01 15:38  SasaL  Views(339)  Comments(0Edit  收藏  举报