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
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
JavaScript
PHP