通过Statement或PreparedStatement执行查询SQL语句后会得到一个结果对象(ResultSet)
一、ResultSet:结果集,操作查询操作后的数据表
本质:ResultSet里有一个行指针,指向数据表,默认指向第一行的上方。
* 有以下方法:
* next():将指针往下移动一行,当返回为true时返回当前指向的行数据,否则为false
* previous():将指针往上移动一行,当返回为true时返回当前指向的行数据,否则为false
* first():将指针重置为第一行
* last():将指针重置为最后一行
* getXxx(int count):得到数据类型为Xxx的第count列数据
* getXxx(String name):得到数据类型为Xxx的列名为name的数据
* getMetaData():获得ResultSetMetaData对象
以下为操作示例:
//获得表table_01所有数据的SQL语句
String sql="select* from table_01";
Connection connection=JDBCTools.getConnection(); //JDBCTools为后面集合的工具类,封装了一些方法
Statement statement=connection.createStatement();
ResultSet resultset=statement.executeQuery(sql);
System.out.println("name"+"\tid"+"\tsex");
while(resultset.next()!=false) {
String name=resultset.getString(1);
int id=resultset.getInt(2);
String sex=resultset.getString("sex");
System.out.println(name+"\t"+id+"\t"+sex);
}
JDBCTools.release(connection, statement,resultset); //statement、resultset都需要关闭
二、ResultSetMetaData:查询后的数据表的信息对象
ResultSetMetaData对象:通过ResultSet的getMetaData方法获得。
提供了以下方法:
getColumnCount():获得当前数据表的列数
getColumnName(int index): 获得当前数据表的列名,从第1列开始,没有第0列。
以下为操作示例:
String sql="select* from table_01";
ResultSet resultset=JDBCTools.Select(sql);
ResultSetMetaData resultsetmetadata=resultset.getMetaData();
System.out.println("table_01表:");
for(int i=0;i<resultsetmetadata.getColumnCount();i++) {
System.out.print(resultsetmetadata.getColumnName(i+1)+"\t");
System.out.println();
while(resultset.next()) {
for(int i=0;i<resultsetmetadata.getColumnCount();i++) {
System.out.print(resultset.getObject(i+1)+"\t");
}
System.out.println();
}