• 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();
                    }
  • 相关阅读:
    cocos2dx注意点
    [转]优化Cocos2d程序的内存消耗
    [转]Cocosdx中介者模式
    [转]Cocos2dx委托模式
    [转]cocos2dx场景切换时内存过高导致crash解决方法
    SQL语句字符串处理大全(转)
    C#不区分大小写的字符串替换(Replace)函数(转)
    lucene.net 分词 搜索
    起点上的页面传值js,有空研究下
    正则表达式取网页链接以及标题,包含单、双引号,以及没有引号的情况
  • 原文地址:https://www.cnblogs.com/MrQlyn/p/10236348.html
Copyright © 2020-2023  润新知