1.DQL代码
不同于前面的DML过程的是,将原来的sql语句改成DQL,并且调用statement的executeQuery() 方法执行查询,返回结果使用ResultSet 进行接收。
String sql = "select * from student";
ResultSet rs = stmt.executeQuery(sql);
完了?没呢!
这个rs保存了查询返回的结果集,并没有读取出来呢,究竟怎么读呢?首先让我们了解一下ResultSet
2.ResultSet 的功能
这个ResultSet 究竟是个什么鬼呢?查看API文档之后,总结如下:
2.1 ResultSet 对象具有指向其当前数据行的光标。 最初,光标被置于第一行之前。调用 next() 方法将光标移动到下一行;
因为该方法在 ResultSet 对象没有下一行时返回 false, 所以可以在 while 循环中使用它来迭代结果集,调用getXXX(int fieldIndex)/getXXX(String columnName)方法获取字段值。
2.2 ResultSet 接口提供用于从当前行获取列值的获取方法(getBoolean、getLong 等)。
可以使用列的索引编号或列的名称获取值。一般情况下,使用列索引较为高效。列从 1开始编号。为了获得最大的可移植性,应该按从左到右的顺序读取每行中的结果集列, 每列只能读取一次。
2.3 用作获取方法的输入的列名称不区分大小写
3.写代码读取ResultSet
好了,这下已经明白了它的用途,我们写一个程序来读取它吧
3.1 读取方法1 – 通过索引来遍历读取
while(rs.next()){
int id = rs.getInt(1);
String name = rs.getString(2);
String gender = rs.getString(3);
System.out.println("id:"+id+" 姓名:"+name+" 性别:"+gender);
}
3.2 读取方法2 – 通过字段名称来读取
强调一下,这个传入的字段名称可以不区分大小写,因为在mysql中就是不区分的
while(rs.next()){
int id = rs.getInt("id");
String name = rs.getString("name");
String gender = rs.getString("gender");
System.out.println("id:"+id+" 姓名:"+name+" 性别:"+gender);
}