java中dao层的通用层,通过反射机制,操作数据库的增删改,适用的范围是不包含属性类
这里首先必须注意的是:类的类名、字段必须与数据库中的表名和字段名保持一致,否则无法通过反射机制作出通用层
/**
* 学生信息类,数据库中的StuInfo表
* */
public class StuInfo {
private int StuId;
private String StuName;
public StuInfo() {
}
public StuInfo(int stuId, String stuName) {
StuId = stuId;
StuName = stuName;
}
public StuInfo(String stuName) {
StuName = stuName;
}
public int getStuId() {
return StuId;
}
public void setStuId(int stuId) {
StuId = stuId;
}
public String getStuName() {
return StuName;
}
public void setStuName(String stuName) {
StuName = stuName;
}
}
/**
* 成绩类,数据库中的StuScoreInfo表
* */
public class StuScoreInfo {
private int StuScoreId;
private int StuId;
private int StuScore;
public StuScoreInfo(int stuId, int stuScore) {
StuId = stuId;
StuScore = stuScore;
}
public StuScoreInfo(int stuScoreId, int stuId, int stuScore) {
StuScoreId = stuScoreId;
StuId = stuId;
StuScore = stuScore;
}
public StuScoreInfo() {
}
public int getStuScoreId() {
return StuScoreId;
}
public void setStuScoreId(int stuScoreId) {
StuScoreId = stuScoreId;
}
public int getStuId() {
return StuId;
}
public void setStuId(int stuId) {
StuId = stuId;
}
public int getStuScore() {
return StuScore;
}
public void setStuScore(int stuScore) {
StuScore = stuScore;
}
}
//dao层的通用类,适用于没有属性类的类,对于增删改的重构
public class CurrencyDao {
/**
* 添加语句,适用于没有属性类的任何类
* */
public int Insert(Object o) {
int judge = -1;
// 反射出私有字段
Field[] f = o.getClass().getDeclaredFields();
// 组装数组库语句
String sql = "insert into " + o.getClass().getSimpleName();// o.getClass().getSimpleName()获取的是没有包名的
sql += "(";
for (int i = 1; i < f.length; i++) {
// 连接字段名
sql += f[i].getName() + ",";
}
// 因为最后会多出‘,’,所以通过substring截取掉
sql = sql.substring(0, sql.lastIndexOf(','));
sql += ") values (";
for (int i = 1; i < f.length; i++) {
sql += "?,";
}
sql = sql.substring(0, sql.lastIndexOf(',')) + ")";
PreparedStatement pstm = null;
Connection conn = ConnDB.getConn();
try {
pstm = conn.prepareStatement(sql);
Object object = pstm;
// 获取到prepareStatement类
Class<? extends Object> claPstm = object.getClass();
// 获取prepareStatement中的公有方法
Method[] methods = claPstm.getMethods();
// 为sql中的?赋值
for (int i = 1; i < f.length; i++) {
// 暴力反射
f[i].setAccessible(true);
for (Method method : methods) {
// 获取方法名
String name = method.getName();
// 截取,目的是为了跟字段的类型做比较
int index = name.indexOf("t") + 1;
// 如果方法名没有出现t字符,则返回的索引值为-1,这样通过截取会报错
if (index < 0) {
continue;
}
// 截取方法的类型的名称,比如setInt则截取剩下int跟要添加的类的字段的类型名进行比较
if (name.substring(index).equalsIgnoreCase( f[i].getType().getSimpleName())) {
// 拿到prepareStatement中对应的方法,run
method.invoke(object, i, f[i].get(o));
break;
}
}
}
judge = pstm.executeUpdate();
} catch (Exception e) {
e.printStackTrace();
} finally {
ConnDB.close(pstm, null, null, conn);
}
return judge;
}
/**
* 修改,适用于没有属性类的类进行数据库修改
* @param o 类
* @return 受影响行数
*/
public int update(Object o) {
int judge = -1;
// 反射出私有字段
Field[] f = o.getClass().getDeclaredFields();
// 组装数组库语句
String sql = "update " + o.getClass().getSimpleName();// o.getClass().getSimpleName()获取的是没有包名的
sql += " set ";
for (int i = 1; i < f.length; i++) {
// 连接字段名
sql += f[i].getName() + "=?,";
}
// 因为最后会多出‘,’,所以通过substring截取掉
sql = sql.substring(0, sql.lastIndexOf(','));
sql+=" where "+f[0].getName()+"=?";
PreparedStatement pstm = null;
Connection conn = ConnDB.getConn();
try {
pstm = conn.prepareStatement(sql);
Object object = pstm;
// 获取到prepareStatement类
Class<? extends Object> claPstm = object.getClass();
// 获取prepareStatement中的公有方法
Method[] methods = claPstm.getMethods();
int index=0;
// 为sql中的?赋值
for (; index < f.length; index++) {
// 暴力反射
f[index].setAccessible(true);
for (Method method : methods) {
// 获取方法名
String name = method.getName();
// 截取,目的是为了跟字段的类型做比较
int index1 = name.indexOf("t") + 1;
// 如果方法名没有出现t字符,则返回的索引值为-1,这样通过截取会报错
if (index1 < 0) {
continue;
}
// 截取方法的类型的名称,比如setInt则截取剩下int跟要添加的类的字段的类型名进行比较
if (name.substring(index1).equalsIgnoreCase(
f[index].getType().getSimpleName())) {
if(index>0){
// 拿到prepareStatement中对应的方法,run
method.invoke(object, index, f[index].get(o));
}else {
// 拿到prepareStatement中对应的方法,run
method.invoke(object, f.length, f[index].get(o));
}
}
}
}
judge = pstm.executeUpdate();
} catch (Exception e) {
e.printStackTrace();
} finally {
ConnDB.close(pstm, null, null, conn);
}
return judge;
}
/**
* 删除
* @param o 类
* @return 受影响行数
*/
public int delete(Object o) {
int judge = -1;
// 反射出私有字段
Field[] f = o.getClass().getDeclaredFields();
// 组装数组库语句
String sql = "delete from " + o.getClass().getSimpleName();// o.getClass().getSimpleName()获取的是没有包名的
sql += " where ";
// 连接字段名
sql += f[0].getName() + "=?";
PreparedStatement pstm = null;
Connection conn = ConnDB.getConn();
try {
pstm = conn.prepareStatement(sql);
Object object = pstm;
// 获取到prepareStatement类
Class<? extends Object> claPstm = object.getClass();
// 获取prepareStatement中的公有方法
Method[] methods = claPstm.getMethods();
int index=0;
// 为sql中的?赋值
// 暴力反射
f[index].setAccessible(true);
for (Method method : methods) {
// 获取方法名
String name = method.getName();
// 截取,目的是为了跟字段的类型做比较
int index1 = name.indexOf("t") + 1;
// 如果方法名没有出现t字符,则返回的索引值为-1,这样通过截取会报错
if (index1 < 0) {
continue;
}
// 截取方法的类型的名称,比如setInt则截取剩下int跟要添加的类的字段的类型名进行比较
if (name.substring(index1).equalsIgnoreCase(
f[index].getType().getSimpleName())) {
// 拿到prepareStatement中对应的方法,run
method.invoke(object, index+1, f[index].get(o));
}
}
judge = pstm.executeUpdate();
} catch (Exception e) {
e.printStackTrace();
} finally {
ConnDB.close(pstm, null, null, conn);
}
return judge;
}
}
java中dao层的通用层,通过反射机制,操作数据库的增删改,适用的范围是不包含属性类的更多相关文章
- java操作数据库:增删改查
不多bb了直接上. 工具:myeclipse 2016,mysql 5.7 目的:java操作数据库增删改查商品信息 test数据库的goods表 gid主键,自增 1.实体类Goods:封装数据库数 ...
- Java操作数据库实现"增删改查"
本文主要讲解JDBC操作数据库 主要实现对MySql数据库的"增删改查" 综合概述: JDBC的常用类和接口 一 DriverManager类 DriverManage类 ...
- Java数据库连接——JDBC基础知识(操作数据库:增删改查)
一.JDBC简介 JDBC是连接java应用程序和数据库之间的桥梁. 什么是JDBC? Java语言访问数据库的一种规范,是一套API. JDBC (Java Database Connectivit ...
- Java数据库连接--JDBC基础知识(操作数据库:增删改查)
一.JDBC简介 JDBC是连接java应用程序和数据库之间的桥梁. 什么是JDBC? Java语言访问数据库的一种规范,是一套API. JDBC (Java Database Connectivit ...
- java中如何操作数据库(增删改查)
EntityManager 是用来对实体Bean 进行操作的辅助类.他可以用来产生/删除持久化的实体Bean,通过主键查找实体bean,也可以通过EJB3 QL 语言查找满足条件的实体Bean.实体B ...
- java程序设计课期中考试——数据库的增删改查和简单的js界面
首先是设计思路,对于数据库的增删改查,我们借助Ecilipse来进行前端和后端的编写.Ecilipse是可以进行java web项目的操作的. 前端,我们选择用使用jsp,所谓的jsp就是可以嵌入其他 ...
- 用C#实现对MSSqlServer数据库的增删改查---DAL层
说明:本人完成的工作是对传感器--超声波物位计进行硬件集成,上位机通过串口接收传感器数据并将其存到数据库中:在DAL层实现对数据库的增删改查,其中包含两个数据表分别是WaterLevelSet表和Wa ...
- Java中的ReentrantLock和synchronized两种锁定机制的对比
问题:多个访问线程将需要写入到文件中的数据先保存到一个队列里面,然后由专门的 写出线程负责从队列中取出数据并写入到文件中. http://blog.csdn.net/top_code/article/ ...
- Java基础-Java中的堆内存和离堆内存机制
Java基础-Java中的堆内存和离堆内存机制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.
随机推荐
- Python - 缩写(capwords) 和 创建转换表(maketrans) 详细说明
缩写(capwords) 和 创建转换表(maketrans) 详细说明 本文地址: http://blog.csdn.net/caroline_wendy/article/details/27051 ...
- rman(上)
CHANGE命令更改备份和副本的状态 1.change backupset 100 unavailable CATALOG命令是用来备份的碎片和复制信息到RMAN数据库 1.息增加到RMAN ...
- Custom Data Service Providers
Custom Data Service Providers Introduction Data Services sits above a Data Service Provider, which i ...
- android EditText问题多行文本输入
一旦习惯了网络和swing在文本框输入,我们Android突然缺乏这样的管制,刚开始使用它是相当费力.为了要实现多行文本输入框和显示.逐一克服这些问题,如下面: 1. 怎么做EditText显示区域在 ...
- Java和Flex积分误差(一个)
1.错误叙述性说明 at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency( ...
- crawler_爬虫分布式设计图收集_01
- WPF - Visual调试工具Snoop
原文:WPF - Visual调试工具Snoop Snoop经过很长一段时间,最近更新到支持NET 3.5了,它是一个WPF运行时对Visual UI调试的一个工具,最近我用过它调试修改过一个bug, ...
- CSharp设计模式读书笔记(14):职责链模式(学习难度:★★★☆☆,使用频率:★★☆☆☆)
职责链模式(Chain of Responsibility Pattern):避免请求发送者与接收者耦合在一起,让多个对象都有可能接收请求,将这些对象连接成一条链,并且沿着这条链传递请求,直到有对象 ...
- nginx跳转
语法规则: location [=|~|~*|^~] /uri/ { - } = 开头表示精确匹配 ^~ 开头表示uri以某个常规字符串开头,理解为匹配 url路径就可以.nginx不正确url做 ...
- Codeforces #180 div2 C Parity Game
// Codeforces #180 div2 C Parity Game // // 这个问题的意思被摄物体没有解释 // // 这个主题是如此的狠一点(对我来说,),不多说了这 // // 解决问 ...