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();
                    }
  • 相关阅读:
    几维安全SDK应用加固,全线5折为APP保驾护航
    物联网渗透测试威胁建模,捕捉应用相关安全风险
    【几维安全】Android代码混淆,代码混淆工具,Android版使用详细说明
    畅想物联网安全未来,几维安全让万物互联更安全
    域起网络携手几维安全,护航互联网游戏业务安全
    Android 加密, Android 常用加密, Android So 库高强度加密
    车联网安全威胁分析及防护思路,几维安全为智能汽车保驾护航
    C#实现基于ffmpeg加虹软的人脸识别
    OSX 下搭建Asp.Net vNext的开发环境
    验证码识别记录
  • 原文地址:https://www.cnblogs.com/MrQlyn/p/10236348.html
Copyright © 2011-2022 走看看