JDBC-DAO层数据访问工具类的实现

Posted yhgn

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JDBC-DAO层数据访问工具类的实现相关的知识,希望对你有一定的参考价值。

private static PreparedStatement pst;
private static ResultSet rst;

public static <T> int insert(Connection conn, String sql, Class<T> clz, T vo) throws Exception {
pst = conn.prepareCall(sql);
// 为sql设置占位符内容
String[] split = sql.split("\(")[1].split("\)")[0].split(",");
for (int i = 0; i < split.length; i++) {
// 通过反射获取字段
Field f = vo.getClass().getDeclaredField(split[i]);
// 取消私有封装
f.setAccessible(true);

//取得字段对应的属性的值
Object fvalue = f.get(vo);
pst.setObject(i + 1, fvalue);

}
return pst.executeUpdate();
}

public <T> int update(Connection conn,String sql,T vo) throws Exception {
pst=conn.prepareStatement(sql);

String[] split = sql.split("SET")[1].split("WHERE")[0].split(",");
int i=0;
for ( i = 0; i < split.length; i++) {
String column = split[i].split("=")[0];
Field f = vo.getClass().getDeclaredField(column.trim());
f.setAccessible(true);
Object fvalue = f.get(vo);
pst.setObject(i + 1, fvalue);
}

[1]表示开始 [0]表示结束//代表中间的内容
String st = sql.split("WHERE")[1].split("=")[0];

//st.trim 表示去掉多余空格
Field declared = vo.getClass().getDeclaredField(st.trim());
declared.setAccessible(true);
Object fvalue = declared.get(vo);
pst.setObject(i + 1, fvalue);
return pst.executeUpdate();
}

 

以上是关于JDBC-DAO层数据访问工具类的实现的主要内容,如果未能解决你的问题,请参考以下文章

一个JDBC访问oracle数据库表的例子,让你搞清三层架构与MVC框架模式之间的关系,以及满足设计原则的类的结构和各类的职责

实现数据访问层抽象

如何使用JDBC实现数据访问对象层(DAO)

数据访问层的单元测试

项目架构的一点猜想

数据访问层之Repository