java basedao 封装_封装basedao及动态创建新类型的java数组

本文介绍了一个基于Java的BaseDAO抽象类,用于封装常见的数据库操作,如查询、更新、保存、删除等。BaseDAO利用反射机制处理不同类型的对象,并提供了通用的查询方法executeQuery和executeUpdate,以及根据ID查找、分页查找等功能。此外,还展示了如何处理结果集和回调函数CallBack。
摘要由CSDN通过智能技术生成

package com.huawei.base;

import java.io.Serializable;

import java.lang.reflect.Array;

import java.lang.reflect.Field;

import java.lang.reflect.Method;

import java.lang.reflect.ParameterizedType;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.ResultSetMetaData;

import java.sql.SQLException;

import java.util.ArrayList;

import java.util.List;

import com.huawei.common.CallBack;

import com.huawei.common.Page;

import com.huawei.utils.BeanUtil;

import com.huawei.utils.DBUtil;

/**

* @author Administrator

*

*

* void executeQuery(String sql,Object[] parmas,CallBack callback)通用的查询

* void executeUpdate(String sql,Object[] parmas)//通用的执行

*

* List findAll()//查询全部

* Object findOne(Integer id)//根据id查询一个

*

* void save(Object o)//给定一个对象 然后存储到数据库

*

* void update(Object o)//根据一个对象 更新数据库中所对应的字段

*

* void delete(Object o)//根据一个对象删除数据库中 对应的记录

* void deleteById(Integer id)//根据传入的id删除

* void delete(String sql,Object[] params)//自定义删除

*

*

*

*

*/

public abstract class BaseDAO {

//目标类 用于 反射

protected Class clazz;

@SuppressWarnings("unchecked")

public BaseDAO() {

ParameterizedType type = (ParameterizedType) this.getClass().getGenericSuperclass();

//得到类上面的泛型参数的实际类型

clazz = (Class) type.getActualTypeArguments()[0];

}

/**

* 通用的查寻方法

* @param sql给定一个sql语句

* @param params给定与sql语句中相对应的参数

* @param callBack用于处理结果集的回调函数

*/

public void executeQuery(String sql,Object []params,CallBack callBack){

Connection connection = DBUtil.getConnection();

PreparedStatement ps = null;

ResultSet rs = null;

try {

ps = connection.prepareStatement(sql);

//处理参数

if(params!=null && params.length>0){

for(int i=0;i

ps.setObject(i+1, params[i]);

}

}

System.out.println("ORM:"+sql);

rs = ps.executeQuery();

//处理业务逻辑

callBack.execute(rs);

} catch (SQLException e) {

e.printStackTrace();

}finally{

DBUtil.close(rs,ps,connection);

}

}

/**

* 除了查询以外 的所有操作

* @param sql给定一个sql语句

* @param params 参数

*/

public void executeUpdate(String sql,Object []params){

Connection connection = DBUtil.getConnection();

PreparedStatement ps = null;

try {

ps = connection.prepareStatement(sql);

//处理参数

if(params!=null && params.length>0){

for(int i=0;i

ps.setObject(i+1, params[i]);

}

}

System.out.println("ORM:"+sql);

ps.executeUpdate();

} catch (SQLException e) {

e.printStackTrace();

}finally{

DBUtil.close(ps,connection);

}

}

/**

* 通用查询

* @param sql

* @param params

* @return

*/

public List find(String sql,Object []params){

final List result = new ArrayList();

this.executeQuery(sql, params, new CallBa

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值