这里首先必须注意的是:类的类名、字段必须与数据库中的表名和字段名保持一致,否则无法通过反射机制作出通用层

/**
 * 学生信息类,数据库中的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层的通用层,通过反射机制,操作数据库的增删改,适用的范围是不包含属性类的更多相关文章

  1. java操作数据库:增删改查

    不多bb了直接上. 工具:myeclipse 2016,mysql 5.7 目的:java操作数据库增删改查商品信息 test数据库的goods表 gid主键,自增 1.实体类Goods:封装数据库数 ...

  2. Java操作数据库实现"增删改查"

    本文主要讲解JDBC操作数据库    主要实现对MySql数据库的"增删改查" 综合概述: JDBC的常用类和接口 一   DriverManager类 DriverManage类 ...

  3. Java数据库连接——JDBC基础知识(操作数据库:增删改查)

    一.JDBC简介 JDBC是连接java应用程序和数据库之间的桥梁. 什么是JDBC? Java语言访问数据库的一种规范,是一套API. JDBC (Java Database Connectivit ...

  4. Java数据库连接--JDBC基础知识(操作数据库:增删改查)

    一.JDBC简介 JDBC是连接java应用程序和数据库之间的桥梁. 什么是JDBC? Java语言访问数据库的一种规范,是一套API. JDBC (Java Database Connectivit ...

  5. java中如何操作数据库(增删改查)

    EntityManager 是用来对实体Bean 进行操作的辅助类.他可以用来产生/删除持久化的实体Bean,通过主键查找实体bean,也可以通过EJB3 QL 语言查找满足条件的实体Bean.实体B ...

  6. java程序设计课期中考试——数据库的增删改查和简单的js界面

    首先是设计思路,对于数据库的增删改查,我们借助Ecilipse来进行前端和后端的编写.Ecilipse是可以进行java web项目的操作的. 前端,我们选择用使用jsp,所谓的jsp就是可以嵌入其他 ...

  7. 用C#实现对MSSqlServer数据库的增删改查---DAL层

    说明:本人完成的工作是对传感器--超声波物位计进行硬件集成,上位机通过串口接收传感器数据并将其存到数据库中:在DAL层实现对数据库的增删改查,其中包含两个数据表分别是WaterLevelSet表和Wa ...

  8. Java中的ReentrantLock和synchronized两种锁定机制的对比

    问题:多个访问线程将需要写入到文件中的数据先保存到一个队列里面,然后由专门的 写出线程负责从队列中取出数据并写入到文件中. http://blog.csdn.net/top_code/article/ ...

  9. Java基础-Java中的堆内存和离堆内存机制

    Java基础-Java中的堆内存和离堆内存机制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.

随机推荐

  1. 实现双8bit数据指定的位置0要么1

    <pre name="code" class="cpp"> 方法一 #include<stdio.h> #include<math ...

  2. 1005. 继续(3n+1)猜想 (25) (ZJUPAT 数学)

    主题链接:http://pat.zju.edu.cn/contests/pat-b-practise/1005 卡拉兹(Callatz)猜想已经在1001中给出了描写叙述.在这个题目里.情况略微有些复 ...

  3. oracle_安装_win7+64位+Oracle+11g+64位下使用PLSQL+Developer+的解决办法

    1)安装Oracle 11g 64位 2)安装32位的Oracle客户端( instantclient-basic-win32-11.2.0.1.0) 下载instantclient-basic-wi ...

  4. ocp11g培训内部教材_052课堂笔记(042)_体系架构

    OCP 052 课堂笔记 目录 第一部分: Oracle体系架构... 4 第一章:实例与数据库... 4 1.Oracle 网络架构及应用环境... 4 2.Oracle 体系结构... 4 3. ...

  5. ThinkPHP神秘应用架构扩展

    ThinkPHP应用模式提供了机会,改变核心框架.它可以让你的应用程序,以适应环境和其他许多不同的需求. 每一个应用模式都有自己的模式定义文件,相对与ThinkPHP3.1版本号.ThinkPHP3. ...

  6. C/S模式开发中如何利用WebBrowser控件制作导航窗体

    原文:C/S模式开发中如何利用WebBrowser控件制作导航窗体 转自: CSDN 相信不少同学们都做过MIS系统的开发,今天这里不讨论B/S模式开发的问题.来谈谈winform开发.用过市面上常见 ...

  7. $.each()方法详解

    $.each()方法详解 each()函数具有十分强大的遍历功能,可以遍历一维数组.多维数组.Dom.Json等. 在JavaScript中使用$.each可以大大减轻我们的工作量. 1.处理一维数组 ...

  8. ASP.NET 5:依赖注入

    ASP.NET 5:依赖注入 1.背景 如果某个具体的(或类)对象被客户程序所依赖,通常把它们抽象成抽象类或接口.简单说,客户程序摆脱所依赖的具体类型,称之为面向接口编程. 那么问题来了?如何选择客户 ...

  9. 工作笔记3.手把手教你搭建SSH(struts2+hibernate+spring)环境

    上文中我们介绍<工作笔记2.软件开发经常使用工具> 从今天開始本文将教大家怎样进行开发?本文以搭建SSH(struts2+hibernate+spring)框架为例,共分为3步: 1)3个 ...

  10. js 里面 写 C# 代码 遇到的问题

    js  代码块 必须放置在 body 里面