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中的堆内存和离堆内存机制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.
随机推荐
- Cocos2dx 3.0 交流篇
创建项目: For(MAC) Runtime Requirements Android 2.3 or newer iOS 5.0 or newer OS X 10.7 or newer Windows ...
- EXCEL 两人的建立Y轴
在本文中,EXCEL2013基于,操作的其他版本基本上相同模式 原始数据和最后的结果如下面的: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvanloX2p ...
- Spark编译与部署
Spark入门实战系列--2.Spark编译与部署(上)--基础环境搭建 [注] 1.该系列文章以及使用到安装包/测试数据 可以在<倾情大奉送--Spark入门实战系列>获取: 2.S ...
- CentOS 7安装配置Apache HTTP Server
原文 CentOS 7安装配置Apache HTTP Server RPM安装httpd # yum -yinstall httpd //安装httpd会自动安装一下依赖包: apr apr-ut ...
- sqlplus登录问题
问题1.sqlplus login -- SP2-0750: You may need to set ORACLE_HOME to your Oracle software directory 在/e ...
- windows和linux在建筑python集成开发环境IDE
http://blog.csdn.net/pipisorry/article/details/39854707 使用的系统及软件 Ubuntu / windows Python 2.7 / pytho ...
- Nyoj 网络的可靠性(水题)
描述 A公司是全球依靠的互联网解决方案提供商,也是2010年世博会的高级赞助商.它将提供先进的网络协作技术,展示其”智能+互联“的生活概念,同时为参观者提供高品质的个人体验和互动,以”信息通信,尽情城 ...
- android--解--它们的定义tabhost(动态添加的选项+用自己的主动性横向滑动标签+手势切换标签页和内容特征)
在本文中,解决他们自己的定义tabhost实现,并通过代码集成动态加入标签功能.自己主动标签横向滑动功能.和手势标签按功能之间切换. 我完成了这个完美的解决方案一起以下: 1.定义tabwidget布 ...
- 再议 js 数字格式之正则表达式
原文:再议 js 数字格式之正则表达式 前面我们提到到了js的数字格式<浅谈 js 数字格式类型>,之前的<js 正则练习之语法高亮>里也提到了优化数字匹配的正则.不过最近落叶 ...
- c/cpp中怎样切割字符串,相似于split的功能
在python中,假设要求当前时间的unix时间戳,我特别喜欢这么用: import time timestr = time.time() timestamp = int(timestr.split( ...