DatabaseMetaData getResultSetHoldability() 方法及示例
ResultSet 的可保存性决定了当使用 Connection 接口的 commit() 方法提交包含该游标/ResultSet 对象的事务时,ResultSet 对象(游标)是否应该关闭或保持打开状态。
**getResultSetHoldability()** 方法是 DatabaseMetaData 接口的方法,它检索底层数据库的 ResultSet 对象的默认可保存性。
此方法返回一个整数,表示默认的 ResultSet 可保存性,值为 1 或 2,其中:
- 1 表示值 **HOLD_CURSORS_OVER_COMMIT**。如果 ResultSet 对象的可保存性设置为该值,则每当你使用 Connection 接口的 commit() 方法提交/保存事务时,在当前事务中创建的(已打开的)ResultSet 对象将保持打开状态。
- 2 表示值 **CLOSE_CURSORS_AT_COMMIT**。如果 ResultSet 对象的可保存性设置为该值,则每当你使用 Connection 接口的 commit() 方法提交/保存事务时,在当前事务中创建的(已打开的)ResultSet 对象将关闭。
获取 DatabaseMetaData 对象
- 确保你的数据库正在运行。
- 使用 **DriverManager** 类的 **registerDriver()** 方法注册驱动程序。传递与底层数据库对应的驱动程序类的对象。
- 使用 DriverManager 类的 **getConnection()** 方法获取连接对象。将数据库 URL、用户名和数据库用户的密码作为字符串变量传递。
- 使用 Connection 接口的 **getMetaData()** 方法获取当前连接的 **DatabaseMetaData** 对象。
最后,通过调用 DatabaseMetaData 接口的 **getResultSetHoldability()** 方法,获取底层数据库对 ResultSets 可保存性的默认值。
以下 JDBC 程序建立与 MySQL 数据库的连接,并检索底层数据库的默认 ResultSet 可保存性。
示例
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.DriverManager;
import java.sql.SQLException;
public class DatabaseMetadata_getResultSetHoldability {
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......");
//Retrieving the meta data object
DatabaseMetaData metaData = con.getMetaData();
//Retrieving the ResultSet holdability of the current database
int holdability = metaData.getResultSetHoldability();
System.out.print("ResultSet holdability of the underlying database: ");
switch(holdability) {
case 1 :
System.out.print("HOLD_CURSORS_OVER_COMMIT");
break;
case 2 :
System.out.print("CLOSE_CURSORS_AT_COMMIT");
break;
}
}
}输出
Connection established...... ResultSet holdability of the underlying database: HOLD_CURSORS_OVER_COMMIT
广告
数据结构
网络
关系数据库管理系统 (RDBMS)
操作系统
Java
iOS
HTML
CSS
Android
Python
C语言编程
C++
C#
MongoDB
MySQL
Javascript
PHP