JDBC事务的处理

JDBC事务的处理

准备数据

CREATE TABLE account (
​
    id INT PRIMARY KEY AUTO_INCREMENT,
​
    NAME VARCHAR(10),
​
    balance DOUBLE
​
);
​
-- 添加数据
INSERT INTO account (NAME, balance) VALUES ('Jack', 1000), ('Rose', 1000);
​

API介绍

Connection接口中与事务有关的方法说明
void setAutoCommit(boolean autoCommit)参数:true,关闭事务,false开启事务
void commit()提交事务
void rollback()回滚事务

开发步骤

l 使用事务的情况1) 获取连接2) 开启事务3) 获取到PreparedStatement4) 使用PreparedStatement执行两次更新操作5) 正常情况下提交事务6) 出现异常回滚事务7) 最后关闭资源

//事务的操作
public class DemoTransaction {
    public static void main(String[] args) {
        Connection conn = null;
​
        PreparedStatement ps = null;
​
        try {
            //开启 事务
​
            conn = JdbcUtils.getConnection();
​
            conn.setAutoCommit(false);
​
            ps = conn.prepareStatement("update account set balance = balance - 500 where name='jack'");
​
            ps.executeUpdate();  //更新
​
            System.out.println(100 / 0);  //出现异常
​
            ps = conn.prepareStatement("update account set balance = balance + 500 where name='rose'");
​
            ps.executeUpdate();  //更新
​
            //提交事务
​
            conn.commit();
​
            System.out.println("转账成功");
​
        } catch (Exception e) {
​
            System.out.println("转账失败");
​
            //回滚事务
​
            try {
​
                conn.rollback();
​
            } catch (SQLException e1) {
​
                e1.printStackTrace();
​
            }
​
        } finally {
​
            JdbcUtils.close(conn, ps);
        }
    }
}

/**
 * JDBC工具类
 */
public class JdbcUtils {
    //1)    可以把几个字符串定义成常量:用户名,密码,URL,驱动类
    private static final String USER = "root";
    private static final String PASSWORD = "root";
    private static final String URL = "jdbc:mysql://localhost:3306/test";
    private static final String DRIVER = "com.mysql.jdbc.Driver";
​
    //2)    注册驱动,为了兼容以前的程序
    static {
        try {
            Class.forName(DRIVER);
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
    }
​
    /**
     * 得到数据库的连接
     * @return
     */
    public static Connection getConnection() {
        try {
            return DriverManager.getConnection(URL,USER,PASSWORD);
        } catch (SQLException e) {
            throw new RuntimeException(e);
        }
    }
​
    /**
     * 关闭所有打开的资源
     */
    public static void close(Connection conn, Statement stmt) {
        if (stmt!=null) {
            try {
                stmt.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if (conn!=null) {
            try {
                conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }
​
    public static void close(Connection conn, Statement stmt, ResultSet rs) {
        if (rs!=null) {
            try {
                rs.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        close(conn,stmt);
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值