ASP源码.NET源码PHP源码JSP源码JAVA源码DELPHI源码PB源码VC源码VB源码Android源码
当前位置:首页 >> 低调看直播体育app软件下载 >> Javajrs看球网直播吧_低调看直播体育app软件下载_低调看体育直播 >> 将查询的结果封装成List与用回调函数实现数据的动态封装(44)

将查询的结果封装成List与用回调函数实现数据的动态封装(44)

来源:网络整理     时间:2015-04-21     关键词:

本篇文章主要介绍了"将查询的结果封装成List与用回调函数实现数据的动态封装(44)",主要涉及到方面的内容,对于Javajrs看球网直播吧_低调看直播体育app软件下载_低调看体育直播感兴趣的同学可以参考一下: 手工的开始QueryRunner类。实现数据封装:MapListHandler MapHandler BeanListHandler BeanHandl...

 手工的开始QueryRunner类。实现数据封装:

 MapListHandler

  MapHandler

  BeanListHandler

  BeanHandler

第一步:基本的封装测试

       写一个类,QueryRunner,实现一个方法query(sql)- List

package cn.itcast.dbutils;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.sql.DataSource;

public class QueryRunner {
    //接收一个ds
    private DataSource ds;
    public QueryRunner() {
    }
    public QueryRunner(DataSource ds) {
        this.ds = ds;
    }
    /**
     * 只封装成List
     */
    public List<>> query(String sql){
        //封装数据用
        List<>> list = new ArrayList<>>();//声明返回的对象
        Connection con = null;
        try{
            con = ds.getConnection();
            //执行查询
            Statement st = con.createStatement();
            ResultSet rs = st.executeQuery(sql);
            //分析结果集
            ResultSetMetaData rsmd = rs.getMetaData();
            //获取列数
            int cols = rsmd.getColumnCount(); 
            //遍历数据
            while(rs.next()){
                //一行数据
                Map mm = new HashMap();
                //遍历列
                for(int i=0;i<>){
                    //获取列名
                    String colName = rsmd.getColumnName(i+1);
                    //获取数据
                    Object val     = rs.getObject(i+1);
                    //封装到map
                    mm.put(colName, val);
                }
                //将这个map放到list
                list.add(mm);
            }

        }catch(Exception e){
            throw new RuntimeException(e);
        }finally{
            try {
                con.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        return list;
    }
}

用回调函数实现数据的动态封装

回调是指在执行时,具体的封装处理工用由第三方的类来实现。

       回调一般由两部分组成:

       1:调用类 - QueryRunner。实例类

       2:回调规范 – ResultSetHandler。一般是一个接口。

       3:回调规范定义回调方法且这个方法由调用类调用。

package cn.itcast.demo;

import java.util.ArrayList;

import java.util.List;

import org.junit.Test;

public class ThreadDemo {

    /**

     * 测试泛型

     * @throws Exception

     */

    @Test

    public void aa() throws Exception{

       //泛型,在运行时是没有地。

       List list = new ArrayList();

       list.add("ddd");

       List list2 = list;

       list2.add(777);

       list.getClass().getMethod("add",Object.class).invoke(list,909);

       for(Object o:list){

           System.err.println(o+","+o.getClass());

       }

    }

    /**

     * 测试线程

     * @param args

     */

    public static void main(String[] args) {

       new Thread(

              new Runnable() {

                  public void run() {

                     System.err.println("B这是runnable.run。。。。");

                  }

              }

       ){

           public void run() {

              super.run();//调用父类的方法,以执行runnalble.run

              System.err.println("A这是thread.run....");

           };

       }.start();

    }

}

以上就介绍了将查询的结果封装成List与用回调函数实现数据的动态封装(44),包括了方面的内容,希望对Javajrs看球网直播吧_低调看直播体育app软件下载_低调看体育直播有兴趣的朋友有所帮助。

本文网址链接:http://www.codes51.com/article/detail_128806.html

相关图片

相关文章