采用封装及反射原理封装一个将对象装换为对数据库操作的工具类
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(); } }
注:类名必须与表名一致,不区分大小写;

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

Oracle不仅是数据库公司,还是云计算和ERP系统的领导者。1.Oracle提供从数据库到云服务和ERP系统的全面解决方案。2.OracleCloud挑战AWS和Azure,提供IaaS、PaaS和SaaS服务。3.Oracle的ERP系统如E-BusinessSuite和FusionApplications帮助企业优化运营。

十大数字虚拟货币app排行榜分别是:1. OKX,2. Binance,3. gate.io,4. Coinbase,5. Kraken,6. Huobi,7. KuCoin,8. Bitfinex,9. Bitstamp,10. Poloniex。这些交易所根据交易量、用户体验和安全性等因素评选,均提供多种数字货币交易服务和高效的交易体验。

十大数字货币交易所app推荐:1. OKX,2. Binance,3. gate.io,4. Huobi,5. Coinbase,6. KuCoin,7. Kraken,8. Bitfinex,9. Bybit,10. Bitstamp,这些app均提供实时行情、技术分析和价格提醒功能,帮助用户实时监控市场动态并做出明智的投资决策。

十大虚拟币看盘平台app推荐:1. OKX,2. Binance,3. Gate.io,4. Huobi,5. Coinbase,6. Kraken,7. Bitfinex,8. KuCoin,9. Bybit,10. Bitstamp,这些平台提供实时行情、技术分析工具和用户友好的界面,帮助投资者进行有效的市场分析和交易决策。

最适合交易Meme币的平台包括:1. 币安(Binance),全球最大,流动性高,低手续费;2. 欧意(OKX),高效交易引擎,支持多种Meme币;3. XBIT,去中心化,支持跨链交易;4. 雷迪姆(Solana DEX),低成本,结合Serum订单簿;5. PancakeSwap(BSC DEX),交易费用低,速度快;6. Orca(Solana DEX),用户体验优化;7. Coinbase,安全性高,适合新手;8. 火币(Huobi),亚洲知名,交易对丰富;9. DEXRabbit,智能

靠谱好用的虚拟币交易所app是:1. Binance,2. OKX,3. Gate.io,4. Coinbase,5. Kraken,6. Huobi Global,7. Bitfinex,8. KuCoin,9. Bittrex,10. Poloniex。这些平台因其交易量、用户体验和安全性等因素被评选为最佳,均提供注册、验证、存款、提款和交易操作功能。

币圈十大免费看行情软件排名前三分别是OKX、Binance和gate.io。 1. OKX提供简洁界面和实时数据,支持多种图表和市场分析。 2. Binance功能强大,数据准确,适合各种交易者。 3. gate.io以稳定性和全面性着称,适合长期和短线投资者。

适合新手的加密货币数据平台有CoinMarketCap和非小号。1. CoinMarketCap提供全球加密货币实时价格、市值、交易量排名,适合新手与基础分析需求。2. 非小号提供中文友好界面,适合中文用户快速筛选低风险潜力项目。
