Heim > Java > javaLernprogramm > Wann sollten Transaktionen in Java verwendet werden?

Wann sollten Transaktionen in Java verwendet werden?

王林
Freigeben: 2020-02-03 10:29:27
Original
3285 Leute haben es durchsucht

Wann sollten Transaktionen in Java verwendet werden?

Wann werden Transaktionen verwendet?

1. Wenn im tatsächlichen Geschäft ein Datenelement gleichzeitig in zwei Tabellen gespeichert werden muss und die Daten in den beiden Tabellen synchronisiert werden müssen, ist ein Transaktionsverwaltungsmechanismus erforderlich Wird verwendet, um die Datensynchronisation sicherzustellen. Wenn ein Fehler auftritt, beispielsweise das Einfügen von Daten in Tabelle 1 erfolgreich ist, das Einfügen von Daten in Tabelle 2 jedoch fehlschlägt, wird ein Rollback durchgeführt und der Datenpersistenzvorgang wird beendet.

2. Die Softwareentwicklung in der Finanzbranche legt großen Wert auf die Transaktionsverarbeitung. Beispielsweise verringert sich der Betrag des Kontos einer Partei entsprechend der Erhöhung des Kontobetrags der anderen Partei Der Prozess erfordert die Verwendung eines Transaktionsmechanismus, andernfalls kann die Übertragung nicht erfolgreich sein.

Kostenloses Teilen von Lernvideo-Tutorials: Java-Video-Tutorial

Nehmen Sie die JDBC-Transaktionsverarbeitung als Beispiel:

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();
        }
    }
Nach dem Login kopieren

Empfohlene Tutorials zu verwandten Artikeln: Java-Erste-Schritte-Tutorial

Das obige ist der detaillierte Inhalt vonWann sollten Transaktionen in Java verwendet werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage