通过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