ホームページ > Java > &#&チュートリアル > Java でトランザクションを使用する場合

Java でトランザクションを使用する場合

王林
リリース: 2020-02-03 10:29:27
オリジナル
3269 人が閲覧しました

Java でトランザクションを使用する場合

#トランザクションを使用するのはどのような場合ですか?

1. 実際のビジネスにおいて、1 つのデータを 2 つのテーブルに同時に格納する必要があり、2 つのテーブルのデータを同期する必要がある場合、トランザクション管理メカニズムが必要になります。データの同期を確保するために使用されます。たとえば、テーブル 1 へのデータ挿入は成功したが、テーブル 2 へのデータ挿入に失敗した場合など、エラーが発生した場合、テーブル 2 はロールバックされ、データ永続化操作は終了します。

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 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート