JDBC API 支援的交易隔離級別是什麼?


JDBC 透過連線介面提供 5 個事務隔離級別支援。

  • TRANSACTION_NONE: 用整數值 0 表示,不支援事務。

  • TRANSACTION_READ_COMMITTED: 用整數值 2 表示,支援允許不可重複讀和幻讀的事務。

  • TRANSACTION_READ_UNCOMMITTED: 用整數值 1 表示,支援允許髒讀、不可重複讀和幻讀的事務。

  • TRANSACTION_REPEATABLE_READ: 用整數值 4 表示,支援只允許幻讀的事務。

  • TRANSACTION_SERIALIZABLE: 用整數值 8 表示,支援無髒讀、不可重複讀和幻讀事務。

以下 JDBC 示例顯示了 JDBC API 的連線介面提供的全部事務級別。

示例

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
public class TransactionIsolationLevelExample {
   public static void main(String args[]) throws SQLException {
      //Registering the Driver
      DriverManager.registerDriver(new com.mysql.jdbc.Driver());
      //Getting the connection
      String url = "jdbc:mysql:///mydatabase";
      Connection con = DriverManager.getConnection(url, "root", "password");
      System.out.println("Connection established: "+ con);
      System.out.println("TRANSACTION_NONE: "+Connection.TRANSACTION_NONE);
      System.out.println("TRANSACTION_READ_COMMITTED:"+Connection.TRANSACTION_READ_COMMITTED);
      System.out.println("TRANSACTION_READ_UNCOMMITTED: "+Connection.TRANSACTION_READ_UNCOMMITTED);
      System.out.println("TRANSACTION_REPEATABLE_READ: "+Connection.TRANSACTION_REPEATABLE_READ);
      System.out.println("TRANSACTION_SERIALIZABLE: "+Connection.TRANSACTION_SERIALIZABLE);
   }
}

輸出

Connection established: com.mysql.jdbc.JDBC4Connection@6fdb1f78
TRANSACTION_NONE: 0
TRANSACTION_READ_COMMITTED:2
TRANSACTION_READ_UNCOMMITTED: 1
TRANSACTION_REPEATABLE_READ: 4
TRANSACTION_SERIALIZABLE: 8

更新於:2019 年 7 月 30 日

1K+ 檢視

開啟你的 職業

完成課程後獲得認證

開始
廣告