Java Tutorial/Database/ResultSet Holdability — различия между версиями
| Admin (обсуждение | вклад)  м (1 версия) | |
| (нет различий) | |
Текущая версия на 05:06, 1 июня 2010
Check ResultSet Holdability
You can get the result set holdability in three ways.
- int Statement.getResultSetHoldability()
- int DatabaseMetaData.getResultSetHoldability()
- int Connection.getHoldability()
   
   
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.DriverManager;
import java.sql.ResultSet;
public class Main {
  public static void main(String[] args) throws Exception {
    Connection conn = getConnection();
    DatabaseMetaData dbMeta = conn.getMetaData();
    if (dbMeta.supportsResultSetHoldability(ResultSet.HOLD_CURSORS_OVER_COMMIT)) {
      System.out.println("this database hold cursors over commit");
    } else if (dbMeta.supportsResultSetHoldability(ResultSet.CLOSE_CURSORS_AT_COMMIT)) {
      System.out.println("this database close cursors at commit");
    }
    conn.close();
  }
  private static Connection getConnection() throws Exception {
    Class.forName("org.hsqldb.jdbcDriver");
    String url = "jdbc:hsqldb:mem:data/tutorial";
    return DriverManager.getConnection(url, "sa", "");
  }
}
   
   
this database hold cursors over commit
ResultSet Holdability
You may improve database performance by including the ResultSet holdability:
- java.sql.ResultSet.HOLD_CURSORS_OVER_COMMIT
- java.sql.ResultSet.CLOSE_CURSORS_AT_COMMIT
Set ResultSet Holdability Using the Connection Object
   
   
int holdability = java.sql.ResultSet.HOLD_CURSORS_OVER_COMMIT;
conn.setHoldability(holdability);
   
