Java反射实现无Sql语句的DAO抽象类

Java反射实现无Sql语句的DAO抽象类,第1张

Java反射实现无Sql语句的DAO抽象类

明天全栈大作业ddl就要截止了, 晚上我本想再认真检查一遍业务的,但是我看这些相似度80%的XxxDao是在看不顺眼, 于是突发奇想,写了一套完全脱离Sql语句使用的增删查改 *** 作(主要使用了反射, 感觉就是在玩高难度的字符串拼接游戏)

因为只是大作业, 所以用了比较古老的JavaEE,没有上手框架

package dao;

import lombok.SneakyThrows;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import utils.JdbcUtils;

import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.sql.Connection;
import java.util.List;
import java.util.Locale;


public abstract class baseDao{

    QueryRunner runner = new QueryRunner();
    Connection connection = JdbcUtils.getConnection();
    protected Class cls;

    
    private String getClassName(){
        String[] split = cls.getName().split("\.");
        return split[split.length - 1];
    }

    @SneakyThrows
    public T getById(int id){
        String sql = "select * from " + getClassName() +" where id=?";
        return runner.query(connection, sql, new BeanHandler<>(cls), id);
    }

    
    @SneakyThrows
    public List getByName(String pattern){
        String sql;
        String name;
        switch(cls.getName()){
            case "User":{
                name = "username";
                break;
            }
            case "RepoInfo":{
                name = "goodsName";
                break;
            }
            default:{
                name = "name";
            }
        }
        sql = "select * from retail." + getClassName() +  " where " + name + " like ? ";
        return runner.query(connection, sql, new BeanListHandler<>(cls), "%" + pattern + "%");
    }

    
    @SneakyThrows
    public List getAll(){
        String sql = "select * from retail." + getClassName();
        return runner.query(connection, sql, new BeanListHandler<>(cls));
    }

    
    @SneakyThrows
    public boolean deleteById(int id){
        String sql = "delete from retail." + getClassName()  + " where id=?";
        return runner.update(connection, sql, id) > 0;
    }

    
    @SneakyThrows
    public boolean insert(T t) throws NoSuchMethodException, InvocationTargetException, IllegalAccessException{
        Field[] declaredFields = this.cls.getDeclaredFields(); // 所有的属性
        int fieldNum = declaredFields.length; // 属性的数量
        StringBuilder placeHolder = new StringBuilder();
        placeHolder.append("(");
        for(int i = 0; i < fieldNum; i++){
            if(i < fieldNum - 1)
                placeHolder.append("?").append(",");
            else
                placeHolder.append("?");
        }
        placeHolder.append(")");
        String sql = "insert into retail.Goods values" + placeHolder;
        int maxId = getMaxId();
        Object[] paramArray = new Object[fieldNum];
        // 方法对象
        paramArray[0] = maxId + 1;
        for(int i = 1; i < fieldNum; i++){ // 从1开始因为id不需要设置
            String filedName = declaredFields[i].getName(); // 属性名
            String methodName = "get" + filedName.substring(0, 1).toUpperCase(Locale.ROOT) + filedName.substring(1);
            // 合成get属性的方法名
            Method method = this.cls.getDeclaredMethod(methodName);
            // 方法对象
            paramArray[i] = method.invoke(t);
        }
        return runner.update(connection, sql, paramArray) > 0;
    }

    
    @SneakyThrows
    public boolean updateById(T t) throws NoSuchMethodException, InvocationTargetException, IllegalAccessException{
        Field[] declaredFields = this.cls.getDeclaredFields(); // 所有的属性
        int fieldNum = declaredFields.length; // 属性的数量
        StringBuilder placeHolder = new StringBuilder();
        placeHolder.append(" set ");
        for(int i = 1; i < fieldNum; i++){ // 从1开始, 因为不用set id
            if(i < fieldNum - 1)
                placeHolder.append(declaredFields[i].getName()).append("=?,");
            else
                placeHolder.append(declaredFields[i].getName()).append("=?"); // 最后一句set不要逗号
        }
        String sql = "update retail." + getClassName() + placeHolder + " where id=?";
        Object[] paramArray = new Object[fieldNum];
        // 方法对象
        for(int i = 1; i < fieldNum; i++){ // 从1开始, 因为id是最后一个参数
            String filedName = declaredFields[i].getName(); // 属性名
            String methodName = "get" + filedName.substring(0, 1).toUpperCase(Locale.ROOT) + filedName.substring(1);
            // 合成get属性的方法名
            Method method = this.cls.getDeclaredMethod(methodName);
            // 方法对象
            paramArray[i - 1] = method.invoke(t);
        }
        Method method = this.cls.getDeclaredMethod("getId");
        paramArray[fieldNum - 1] = method.invoke(t); // 这个属性是id
        return runner.update(connection, sql, paramArray) > 0;
    }

    
    @SneakyThrows
    private int getMaxId(){
        String sql = "select max(id) from retail." + getClassName();
        return runner.query(connection, sql, new ScalarHandler<>());
    }
}

欢迎大家的批评建议

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5582751.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-14
下一篇 2022-12-14

发表评论

登录后才能评论

评论列表(0条)

保存