zoukankan      html  css  js  c++  java
  • 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"+"	id"+"	sex");
    
                    while(resultset.next()!=false) {
    
                    String name=resultset.getString(1);
    
                    int id=resultset.getInt(2);
    
                    String sex=resultset.getString("sex");
    
                    System.out.println(name+"	"+id+"	"+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)+"	");
    
                                System.out.println();
    
                                while(resultset.next()) {
    
                                for(int i=0;i<resultsetmetadata.getColumnCount();i++) {
    
                                        System.out.print(resultset.getObject(i+1)+"	");
                                }
                        System.out.println();
                    }
  • 相关阅读:
    droid开发:如何打开一个.dcm文件作为位图?
    AndroidStudio3.0 Canary 8注解报错Annotation processors must be explicitly declared now.
    Android 异步加载神器Loader全解析
    Android实现RecyclerView的下拉刷新和上拉加载更多
    Android之ViewFlipper的简单使用
    云计算之路-阿里云上:2014年6月11日17点遇到的CPU 100%状况团队
    云计算之路-阿里云上:黑色1秒,微软的问题还是阿里云的问题?团队
    [网站公告]18:07-18:20阿里云SLB故障造成网站不能正常访问团队
    上周热点回顾(6.2-6.8)团队
    云计算之路-阿里云上:受够了OCS,改用ECS+Couchbase跑缓存团队
  • 原文地址:https://www.cnblogs.com/MrQlyn/p/10236348.html
Copyright © 2011-2022 走看看