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中的堆内存和离堆内存机制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.
随机推荐
- TDD和BDD
开发人员看测试之TDD和BDD 前言: 已经数月没有来园子了,写博客贵在坚持,一旦松懈了,断掉了,就很难再拾起来.但是每每看到自己博客里的博文的浏览量每天都在增加,都在无形当中给了我继续写博客的动 ...
- malloc实现原理
记得早一段时间,看到一本书上写过delete的一个..今天突然找啦一下资料: malloc()是C语言中动态存储管理 的一组标准库函数之中的一个.其作用是在内存的动态存储区中分配一个长度为size的连 ...
- mybatis型材xxxx.xml缺少后果返回类型
下面是一个mybatis型材xxxx.xml失踪resultMap错误: 严重: Servlet.service() for servlet [SpringMVC] in context with p ...
- ABP之动态WebAPI
ABP之动态WebAPI ABP的动态WebApi实现了直接对服务层的调用(其实病没有跨过ApiController,只是将ApiController公共化,对于这一点的处理类似于MVC,对服务端的 ...
- 安装Team Foundation Server 2012过程截图
原文:安装Team Foundation Server 2012过程截图 专题图 1,下载Team Foundation Server 2012 官方下载: http://www.microsoft ...
- java_log4j----java 日志管理
log4j 有三个主要组件: 类别Loggers------消息类型和优先级 附加目的地Appenders-------在哪里报告消息 布局Layouts------控制如何格式化消息 这三个组件共同 ...
- DP 水的问题
假设的自然数N的K随机二进制表示是不相邻的两个相邻的数字.那么我们说这个数字是K好一些. 乞讨L地点K十六进制数K的相当数量的数. 例如K = 4.L = 2什么时候.整个K好一些11.13.20.2 ...
- 【转】Android 常用 adb 命令总结
原文地址:http://testerhome.com/topics/2565 针对移动端 Android 的测试, adb 命令是很重要的一个点,必须将常用的 adb 命令熟记于心, 将会为 Andr ...
- 【高德地图API】从零开始学高德JS API(七)——定位方式大揭秘
原文:[高德地图API]从零开始学高德JS API(七)——定位方式大揭秘 摘要:关于定位,分为GPS定位和网络定位2种.GPS定位,精度较高,可达到10米,但室内不可用,且超级费电.网络定位,分为w ...
- javascript实现数据结构:广义表
原文:javascript实现数据结构:广义表 广义表是线性表的推广.广泛用于人工智能的表处理语言Lisp,把广义表作为基本的数据结构. 广义表一般记作: LS = (a1, a2, ..., an ...