Get a ResultSet Type : ResultSet Type « Database « Java Tutorial






  1. java.sql.ResultSet.TYPE_FORWARD_ONLY
  2. java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE
  3. java.sql.ResultSet.TYPE_SCROLL_SENSITIVE

DatabaseMetaData.supportsResultSetType(): determine which ones are supported.

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

public class Main {
  public static void main(String[] args) throws Exception {
    Connection conn = getConnection();
    Statement st = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,
        ResultSet.CONCUR_UPDATABLE);

    st.executeUpdate("create table survey (id int,name varchar(30));");
    st.executeUpdate("insert into survey (id,name ) values (1,'nameValue')");
    st.executeUpdate("insert into survey (id,name ) values (2,null)");
    st = conn.createStatement();
    ResultSet rs = st.executeQuery("SELECT * FROM survey");

    int rsType = rs.getType();
    if (rsType == java.sql.ResultSet.TYPE_FORWARD_ONLY) {
      System.out.println("java.sql.ResultSet.TYPE_FORWARD_ONLY");
    } else if (rsType == java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE) {
      System.out.println("java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE");
    } else if (rsType == java.sql.ResultSet.TYPE_SCROLL_SENSITIVE) {
      System.out.println("java.sql.ResultSet.TYPE_SCROLL_SENSITIVE");
    } else {
      // it is an error

    }

    rs.close();
    st.close();
    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", "");
  }
}
java.sql.ResultSet.TYPE_FORWARD_ONLY








20.11.ResultSet Type
20.11.1.Get a ResultSet Type
20.11.2.Create Statement and set the ResultSet type: read only, scrollable