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

更新于:2019年7月30日

88 次查看

启动你的职业生涯

完成课程获得认证

开始学习
广告
© . All rights reserved.