首頁 >Java >java教程 >java什麼時候使用事務

java什麼時候使用事務

王林
王林原創
2020-02-03 10:29:273236瀏覽

java什麼時候使用事務

什麼時候使用交易?

1、如果實際的業務中,需要將一條資料同時存放到兩張表中, 並且要求兩張表中的資料同步,那麼此時就需要使用事務管理機制,確保資料同步。如果發生錯誤狀況,例如表一插入資料成功,表二插入資料失敗,那麼就回滾,終止資料持久化操作。

2、金融業的軟體開發嚴格重視事務處理,例如我們常見的轉帳操作,一方的帳戶金額減少,對應的是另一方的帳戶金額增加,這個過程需要使用到事務機制,不然轉帳不能成功。

免費學習影片教學分享:java影片教學

以JDBC處理事務為例:

public static void main(String[] args) throws SQLException, ClassNotFoundException {
        Class.forName("com.mysql.jdbc.Driver");
        String url = "jdbc:mysql://localhost:3306/user";
        String user = "root";
        String password = "123456";
        Connection con = (Connection) DriverManager.getConnection(url, user, password);
        try {
            //取消自动提交
            //如果设成false,那就是JDBC不自动提交,需要手动的使用commit或者rollback来进行提交或者回滚数据. 
            con.setAutoCommit(false);
            Statement stmt = (Statement) con.createStatement();
            //进行数据插入
            String sql = "insert into users(email,password) values('" + "jack@163.com" + "','" + "jack" + "');";
            boolean flag = stmt.execute(sql);
            System.out.println(flag);
            //人为制造一个错误,结果就是数据库并没有插入这条数据,也就是数据发生了回滚
            //异常被捕获之后,就不在执行下面的语句,而是执行catch中的语句
            //如果没有异常,数据就会被提交到数据库
            System.out.println(1/0);
            //手动提交
            con.commit();
        } catch (Exception e) {
            //如果发生错误,就回滚
            con.rollback();
        } finally {
            con.close();
        }
    }

相關文章教學推薦:java入門教學

以上是java什麼時候使用事務的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn