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中的堆内存和离堆内存机制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.
随机推荐
- nodejs使用connect-mongodb报错(Please ensure that you set the default write concern)
原本是使用connect-mongo的,可能是express版本号的升级报错了.改用connect-mongodb.可是使用后出现了例如以下的警告: G:\nodejs\moviesite>gr ...
- 翻译器DIY它———算在英文文本中的单词数,字符和行数
咳咳.这部分应该是序列化编译器DIY的,然而,在这样做DIY第一次使用前flex 为了练练手,对于后者的理解是有帮助. 在word 我经常看到一个字计数功能,因此,它是如何实现,当然,首先想到的是要经 ...
- JAVA连接ACCESS、MYSQL、SQLSEVER、ORACLE数据库
. 概要 1.1 JDBC概念 JDBC(Java Database Connectivity)是Java语言为了支持SQL功能而提供的与数据库连接的用户的接口.JDBC中包含了一组由(Java)语言 ...
- Java工程(3)——但从谈论用户的角度UI图案
前言: 海南项目宣告竣工,验收之日,除部分代码有待优化外,亟待改进的就是界面. 米老师说:连你都忍不住去拖下滚动栏,你还指望用户用的舒坦吗? 顿悟: 业务.功能也许是软件的核心,技术也许是软件的精髓. ...
- 数字使用相应的加密策略传递一个字符串后Java实现代码
公司采用公用电话传递数据,数据小于8整数位,为了确保安全, 在转移的过程中需要加密,加密规则如下面的: 第一个数据下降,附图然后各加5,和除以10的余数取代该数字, ...
- Android开发之自己主动登录功能的实现
在我们平时使用的手机应用都能够实现仅仅须要登陆一次账号后,第二次进入应用直接跳转到效果界面的效果,还有QQ的登陆框是怎样记忆我们的隐身登陆,保存账号选项的呢,这些都是通过使用SharedPrefere ...
- 【Flume NG用户指南】(2)构造
作者:周邦涛(Timen) Email:zhoubangtao@gmail.com 转载请注明出处: http://blog.csdn.net/zhoubangtao/article/details ...
- Windows在配置Python+tornado
1,安装Python 2.7.x版本号 地址:https://www.python.org/downloads/release/python-278/ 2,安装python setuptools工具 ...
- java json字符串转List、Map等对象
List<Map<String, Object>> map = g.fromJson(jsonStr, new TypeToken<List<Map<Stri ...
- JBoss7官方最新版下载地址
JBoss是全世界开发人员共同努力的成果,一个基于J2EE的开放源码的应用server. 由于JBoss代码遵循LGPL许可,能够在不论什么商业应用中免费使用它,而不用支付费用.2006年,Jboss ...