java 查询条件的封装_java—将查询的结果封装成List<Map>与用回调函数实现数据的动态封装(44)...

本文介绍了如何使用Java的QueryRunner类进行数据查询并封装成List,以及利用回调函数实现数据的动态封装。首先展示了QueryRunner类的实现,包括MapListHandler、MapHandler、BeanListHandler和BeanHandler等方法。接着,通过一个示例展示了如何使用回调函数,其中QueryRunner作为调用类,而回调规范定义了一个接口ResultSetHandler。最后,文中提供了测试代码以演示这些功能的使用。
摘要由CSDN通过智能技术生成

手工的开始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 classQueryRunner {//接收一个ds

privateDataSource ds;publicQueryRunner() {

}publicQueryRunner(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 newRuntimeException(e);

}finally{try{

con.close();

}catch(SQLException e) {

e.printStackTrace();

}

}returnlist;

}

}

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

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

回调一般由两部分组成:

1:调用类 - QueryRunner。实例类

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

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

19a630eb1bed44498df4b11aff3a00ca.png

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();

}

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值