package project02_Order_management.dao;import java.lang.reflect.Field;import java.lang.reflect.InvocationTargetException;import java.lang.reflect.Method;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.ResultSet
package project02_Order_management.dao; import java.lang.reflect.Field; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.ArrayList; import java.util.List; public class BaseDao { /** * 查询所有数据方法 */ public static List findAll(Object obj, Connection conn) throws Exception { // 获取要操作对象的类 Class clazz = obj.getClass(); // 获取传入实体的所有方法; Method[] methods = clazz.getDeclaredMethods(); // 获取传入实体中的所有的属性 Field[] fields = clazz.getDeclaredFields(); // 建立结果集List接收对象 List list = new ArrayList(); // 创建查询的sql语句; String sql = "select * from " + obj.getClass().getSimpleName().toLowerCase(); System.out.println(sql); // System.out.println(sql); // 预编译sql语句 PreparedStatement preparedStatement = conn.prepareStatement(sql); ResultSet resultSet = preparedStatement.executeQuery(); // 从结果集中循环取出放入结果集List while (resultSet.next()) { // 查询的结果的接受对象 Object entity = clazz.newInstance(); // 循环类中的属性,进行复制操作 for (int i = 0; i < fields.length; i++) { // 获取属性名称 String fieldName = fields[i].getName(); // 获取result结果集中的每个结果字段的对象 Object fieldObject = resultSet.getObject(i + 1); if (fieldObject == null) { fieldObject = "null";// 防止数据为null时引发空指针异常 } for (int j = 0; j < methods.length; j++) { // 比对属性名加上set后与方法名是否一致,进行对应的属性用对应的方法进行复制操作 if (("set" + fieldName).equalsIgnoreCase(methods[j] .getName())) { // 执行传入对象的指定的方法 methods[j].invoke(entity, resultSet.getObject(fieldName)); } } } list.add(entity); } return list; } /** * 根据id查询数据 * * @throws SQLException * @throws IllegalAccessException * @throws InstantiationException * @throws InvocationTargetException * @throws IllegalArgumentException */ public static Object findById(Object obj, Integer id, Connection conn) throws SQLException, InstantiationException, IllegalAccessException, IllegalArgumentException, InvocationTargetException { // 获取要操作对象的类 Class clazz = obj.getClass(); // 获取传入实体的所有方法; Method[] methods = clazz.getDeclaredMethods(); // 获取传入实体中的所有的属性 Field[] fields = clazz.getDeclaredFields(); // 查询的结果的接受对象 Object entity = null; // 创建查询的sql语句; String sql = "select * from " + clazz.getSimpleName().toLowerCase() + " where id=?"; PreparedStatement preparedStatement = conn.prepareStatement(sql); preparedStatement.setInt(1, id); ResultSet resultSet = preparedStatement.executeQuery(); if (resultSet.next()) { // 根据获取的实体的类,创建实体 entity = clazz.newInstance(); // 循环类中的属性,进行复制操作 for (int i = 0; i < fields.length; i++) { // 获取属性名称 String fieldName = fields[i].getName(); // 获取result结果集中的每个结果字段的对象 Object fieldObject = resultSet.getObject(i + 1); if (fieldObject == null) { fieldObject = "null";// 防止数据为null时引发空指针异常 } for (int j = 0; j < methods.length; j++) { // 比对属性名加上set后与方法名是否一致,进行对应的属性用对应的方法进行复制操作 if (("set" + fieldName).equalsIgnoreCase(methods[j] .getName())) { // 执行传入对象的指定的方法 methods[j].invoke(entity, resultSet.getObject(fieldName)); } } } } return entity; } /** * 分页数据查询 * * @param obj * 传入目标对象 * @param conn * 传入数据库连接 * @param startRow * 传入开始的行数 * @param endRow * 传入结束的行数 */ public static List paging(Object obj, Connection conn, Integer startRow, Integer endRow) { return null; } /** * 保存方法 */ public static void save(Object obj, Connection conn) throws IllegalAccessException, IllegalArgumentException, InvocationTargetException, SQLException { Class clazz = obj.getClass(); Method[] methods = clazz.getDeclaredMethods(); Field[] fields = clazz.getDeclaredFields(); // 获取操作的表单名字,[这里类名必须和表名一致] String table = clazz.getSimpleName().toLowerCase(); String fieldsName = ""; for (int i = 0; i < fields.length; i++) { fieldsName = fieldsName + fields[i].getName() + ","; } fieldsName = fieldsName.substring(0, fieldsName.length() - 1); // 占位符的设置 String placeholder = ""; for (int j = 0; j < fields.length; j++) { // 拼接属性的get的方法名 String str = "get" + fields[j].getName(); for (int k = 0; k < methods.length; k++) { if (str.equalsIgnoreCase(methods[k].getName())) { placeholder = placeholder + "?" + ","; } } } placeholder = placeholder.substring(0, placeholder.length() - 1); // 拼接sql语句 String sql = "insert into " + table + "(" + fieldsName + ")" + " values " + "(" + placeholder + ")"; System.out.println(sql); PreparedStatement pst = conn.prepareStatement(sql); int index = 1; for (int j = 0; j < fields.length; j++) { String str = "get" + fields[j].getName(); // 循环方法名比对 for (int k = 0; k < methods.length; k++) { // 如果当前的属性拼出的get方法名,与方法明集合中的有一样的执行 if (str.equalsIgnoreCase(methods[k].getName())) { // 接收指定的方法执行后的数据 Object p = methods[k].invoke(obj); // 为指定的占位符进行赋值 pst.setObject(index++, p); } } } // 执行已经加载的sql语句 pst.executeUpdate(); } /** * 更新数据 */ public static void update(Object obj, Connection conn) throws Exception { // 修改 Class clazz = obj.getClass(); Method[] methods = clazz.getDeclaredMethods(); Field[] fields = clazz.getDeclaredFields(); /* * 拼接Sql */ String table = clazz.getSimpleName().toLowerCase(); String setField = ""; int id = 1; for (int i = 0; i < fields.length; i++) { for (int j = 0; j < methods.length; j++) { String strGetField = "get" + fields[i].getName(); if (strGetField.equalsIgnoreCase(methods[j].getName())) { /* * 拼接sql语句中的set字段,并用占位符 */ setField = setField + fields[i].getName() + "= ?,"; // 获取id if ("getId".equalsIgnoreCase(methods[j].getName())) { id = Integer .parseInt(methods[j].invoke(obj).toString()); } } } } setField = setField.substring(0, setField.length() - 1); String sql = "update " + table + " set " + setField + " where id= ?"; System.out.println(sql); PreparedStatement pst = conn.prepareStatement(sql); int index = 1; for (int j = 0; j < fields.length; j++) { String str = "get" + fields[j].getName(); // 循环方法名比对 for (int k = 0; k < methods.length; k++) { // 如果当前的属性拼出的get方法名,与方法明集合中的有一样的执行 if (str.equalsIgnoreCase(methods[k].getName())) { // 接收指定的方法执行后的数据 Object p = methods[k].invoke(obj); // 为指定的占位符进行赋值 pst.setObject(index++, p); } } } pst.setObject(index++, id); pst.execute(); } /** * 根据id删除数据 * * @throws SQLException */ public static void delById(Object obj, Integer id, Connection conn) throws SQLException { System.out.println("============="); Class clazz = obj.getClass(); String table = clazz.getSimpleName().toLowerCase(); String sql = "delete from " + table + " where id=?"; System.out.println(sql); PreparedStatement preparedStatement = conn.prepareStatement(sql); preparedStatement.setInt(1, id); preparedStatement.execute(); } }
注:类名必须与表名一致,不区分大小写;

本站4月17日消息,集邦咨询(TrendForce)近日发布报告,认为英伟达Blackwell新平台产品需求看涨,预估带动台积电2024年CoWoS封装总产能提升逾150%。英伟达Blackwell新平台产品包括B系列的GPU,以及整合英伟达自家GraceArmCPU的GB200加速卡等。集邦咨询确认为供应链当前非常看好GB200,预估2025年出货量有望超过百万片,在英伟达高端GPU中的占比达到40-50%。在英伟达计划下半年交付GB200以及B100等产品,但上游晶圆封装方面须进一步采用更复

本站7月9日消息,AMDZen5架构“Strix”系列处理器会有两种封装方案,其中较小的StrixPoint将采用FP8封装,而StrixHalo将会采用FP11封装。图源:videocardz消息源@Olrak29_最新曝料称StrixHalo的FP11封装尺寸为37.5mm*45mm(1687平方毫米),和英特尔AlderLake、RaptorLakeCPU的LGA-1700封装尺寸相同。AMD最新的PhoenixAPU采用FP8封装方案,尺寸为25*40mm,这意味着StrixHalo的F

Golang函数的反射和类型断言的应用和底层实现在Golang编程中,函数的反射和类型断言是两个非常重要的概念。函数的反射可以让我们在运行时动态的调用函数,而类型断言则可以帮助我们在处理接口类型时进行类型转换操作。本文将深入讨论这两个概念的应用以及他们的底层实现原理。一、函数的反射函数的反射是指在程序运行时获取函数的具体信息,比如函数名、参数个数、参数类型等

Vue中Axios封装及其常用方法介绍Axios是一款基于Promise实现的HTTP库,它的优点在于具有良好的可读性、易用性以及可扩展性。Vue作为一款流行的前端框架,也对Axios提供了全面支持。本文将介绍如何在Vue中进行Axios封装,并且介绍Axios常用的一些方法。一、Axios封装在开发过程中,我们常常需要对Axios进行一些自定义的封装,例如

PHP中的封装技术及应用封装是面向对象编程中的一个重要概念,它指的是将数据和对数据的操作封装在一起,以便提供对外部程序的统一访问接口。在PHP中,封装可以通过访问控制修饰符和类的定义来实现。本文将介绍PHP中的封装技术及其应用场景,并提供一些具体的代码示例。一、封装的访问控制修饰符在PHP中,封装主要通过访问控制修饰符来实现。PHP提供了三个访问控制修饰符,

通过封装代码,C++函数可以提高GUI开发效率:代码封装:函数将代码分组到独立单元,使代码易于理解和维护。可重用性:函数可创建通用功能供应用程序中重复使用,减少重复编写和错误。简洁代码:封装代码使主逻辑简洁,便于阅读和调试。

如何在Go语言中实现封装和继承封装和继承是面向对象编程中的两个重要概念,它们可以使代码更加模块化和可维护,同时也为代码的复用提供了便利。本文将介绍在Go语言中如何实现封装和继承,并提供相应的代码示例。封装封装是将数据和功能进行封装,隐藏实现的细节,只暴露必要的接口给外部使用。在Go语言中,封装是通过导出和非导出标识符来实现的。首字母大写的标识符可以被其他包访

PHP代码封装技巧:如何使用类和对象封装可重复使用的代码块摘要:在开发中,经常遇到需要重复使用的代码块。为了提高代码的可维护性和可重用性,我们可以使用类和对象的封装技巧来对这些代码块进行封装。本文将介绍如何使用类和对象封装可重复使用的代码块,并提供几个具体的代码示例。使用类和对象的封装优势使用类和对象的封装有以下几个优势:1.1提高代码的可维护性通过将重复


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

Dreamweaver Mac版
Alat pembangunan web visual
