dao抽取通用方法java_Dao操作的抽取

packagecom.loaderman.demo.c_jdbc;importjava.sql.Connection;importjava.sql.PreparedStatement;importjava.sql.ResultSet;importjava.sql.ResultSetMetaData;importjava.util.ArrayList;importjava.util.List;importcom.loaderman.demo.utils.JdbcUtil;importorg.apache.commons.beanutils.BeanUtils;/*** 通用的dao,自己写的所有的dao都继承此类;

* 此类定义了2个通用的方法:

* 1. 更新

* 2. 查询

*@authorJie.Yuan

**/

public classBaseDao {//初始化参数

privateConnection con;privatePreparedStatement pstmt;privateResultSet rs;/*** 更新的通用方法

*@paramsql 更新的sql语句(update/insert/delete)

*@paramparamsValue sql语句中占位符对应的值(如果没有占位符,传入null)*/

public voidupdate(String sql,Object[] paramsValue){try{//获取连接

con =JdbcUtil.getConnection();//创建执行命令的stmt对象

pstmt =con.prepareStatement(sql);//参数元数据: 得到占位符参数的个数

int count =pstmt.getParameterMetaData().getParameterCount();//设置占位符参数的值

if (paramsValue != null && paramsValue.length > 0) {//循环给参数赋值

for(int i=0;i

pstmt.setObject(i+1, paramsValue[i]);

}

}//执行更新

pstmt.executeUpdate();

}catch(Exception e) {throw newRuntimeException(e);

}finally{

JdbcUtil.closeAll(con, pstmt,null);

}

}/*** 查询的通用方法

*@paramsql

*@paramparamsValue*/

public List query(String sql, Object[] paramsValue,Classclazz){try{//返回的集合

List list = new ArrayList();//对象

T t = null;//1. 获取连接

con =JdbcUtil.getConnection();//2. 创建stmt对象

pstmt =con.prepareStatement(sql);//3. 获取占位符参数的个数, 并设置每个参数的值//int count = pstmt.getParameterMetaData().getParameterCount();

if (paramsValue != null && paramsValue.length > 0) {for (int i=0; i

pstmt.setObject(i+1, paramsValue[i]);

}

}//4. 执行查询

rs =pstmt.executeQuery();//5. 获取结果集元数据

ResultSetMetaData rsmd =rs.getMetaData();//---> 获取列的个数

int columnCount =rsmd.getColumnCount();//6. 遍历rs

while(rs.next()) {//要封装的对象

t =clazz.newInstance();//7. 遍历每一行的每一列, 封装数据

for (int i=0; i

String columnName = rsmd.getColumnName(i + 1);//获取每一列的列名称, 对应的值

Object value =rs.getObject(columnName);//封装: 设置到t对象的属性中 【BeanUtils组件】

BeanUtils.copyProperty(t, columnName, value);

}//把封装完毕的对象,添加到list集合中

list.add(t);

}returnlist;

}catch(Exception e) {throw newRuntimeException(e);

}finally{

JdbcUtil.closeAll(con, pstmt, rs);

}

}

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值