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