Java 和 MySQL - 查看 ResultSet
ResultSet 接口包含数十种用于获取当前行数据的方法。
每种可能的数据类型都有一个 get 方法,每个 get 方法都有两个版本 −
一个接受列名。
一个接受列索引。
例如,如果您想要查看的列包含 int,则需要使用 ResultSet 的 getInt() 方法之一 −
S.N. | 方法 &描述 |
---|---|
1 | public int getInt(String columnName) throws SQLException
返回当前行中名为 columnName 的列的 int。 |
2 | public int getInt(int columnIndex) throws SQLException
返回指定列索引中当前行的 int。列索引 从 1 开始,即一行的第一列为 1,第二列为 2,依此类推。 |
同样,ResultSet 接口中针对八种 Java 基本类型以及 java.lang.String、java.lang.Object 和 java.net.URL 等常见类型都有获取方法。
还有用于获取 SQL 数据类型 java.sql.Date、java.sql.Time、java.sql.TimeStamp、java.sql.Clob 和 java.sql.Blob 的方法。查看文档以获取有关使用这些 SQL 数据类型的更多信息。
以下是使用描述的几种查看方法的示例。
此示例代码是根据前几章中的环境和数据库设置编写的。
将以下示例复制并粘贴到 TestApplication.java 中,按如下方式编译并运行 −
import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; public class TestApplication { static final String DB_URL = "jdbc:mysql://localhost/TUTORIALSPOINT"; static final String USER = "guest"; static final String PASS = "guest123"; static final String QUERY = "SELECT id, first, last, age FROM Employees"; public static void main(String[] args) { // 打开连接 try(Connection conn = DriverManager.getConnection(DB_URL, USER, PASS); Statement stmt = conn.createStatement( ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY); ResultSet rs = stmt.executeQuery(QUERY); ) { // 将光标移到最后一行。 System.out.println("Moving cursor to the first row..."); rs.last(); // 从结果集提取数据 System.out.println("Displaying record..."); //按列名检索 int id = rs.getInt("id"); int age = rs.getInt("age"); String first = rs.getString("first"); String last = rs.getString("last"); // 显示值 System.out.print("ID: " + id); System.out.print(", Age: " + age); System.out.print(", First: " + first); System.out.println(", Last: " + last); // 将光标移到第一行。 System.out.println("Moving cursor to the first row..."); rs.first(); // 从结果集中提取数据 System.out.println("Displaying record..."); // 按列名检索 id = rs.getInt("id"); age = rs.getInt("age"); first = rs.getString("first"); last = rs.getString("last"); // 显示值 System.out.print("ID: " + id); System.out.print(", Age: " + age); System.out.print(", First: " + first); System.out.println(", Last: " + last); // 将光标移动到第一行。 System.out.println("Moving cursor to the next row..."); rs.next(); // 从结果集中提取数据 System.out.println("Displaying record..."); id = rs.getInt("id"); age = rs.getInt("age"); first = rs.getString("first"); last = rs.getString("last"); // 显示值 System.out.print("ID: " + id); System.out.print(", Age: " + age); System.out.print(", First: " + first); System.out.println(", Last: " + last); } catch (SQLException e) { e.printStackTrace(); } } }
现在让我们编译上面的例子如下 −
C:\>javac TestApplication.java C:\>
当您运行 TestApplication 时,它会产生以下结果 −
C:\>java TestApplication Moving cursor to the last... Displaying record... ID: 103, Age: 30, First: Sumit, Last: Mittal Moving cursor to the first row... Displaying record... ID: 100, Age: 18, First: Zara, Last: Ali Moving cursor to the next row... Displaying record... ID: 101, Age: 25, First: Mehnaz, Last: Fatma C:\>