JDBC学习笔记(查询SQL语句得到的结果对象)

通过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();
                }

 

转载于:https://www.cnblogs.com/MrQlyn/p/10236348.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值