• 封装与职责分离的开发思维


    1:封装:参数过多应该封装成一个对象

    2:职责分离:谁拥有该数据,谁就应该包含操作该数据的方法

    ■ 举例:没有封装【多个查询条件作为参数 (String name, Integer minAge, Integer maxAge, Integer dormBuildId)

        @Override
        public List<Teacher> query(String name, Integer minAge, Integer maxAge, Integer dormBuildId) {
            StringBuilder sql = new StringBuilder();
            sql.append("SELECT * FROM t_teacher WHERE 1=1");
            //封装占位符参数
            List<Object> parameters = new ArrayList<>();
    //拼接sql和设置占位符参数值

       //姓名 if (StringUtils.isNotBlank(name)) { sql.append(" AND name LIKE ?"); parameters.add("%" + name + "%"); } //最小年龄 if(minAge != null) { sql.append(" AND age >= ?"); parameters.add(minAge); } //最大年龄 if(maxAge != null) { sql.append(" AND age <= ?"); parameters.add(maxAge); } System.out.println("sql=" + sql); System.out.println("parameters=" + parameters); return JdbcTemplate.query(sql.toString(), new BeanListHandler<>(Teacher.class), parameters.toArray()); }

    ■ 封装:将多个查询条件参数 (String name, Integer minAge, Integer maxAge, Integer dormBuildId) 封装成一个对象:

    @Data
    public class TeacherQueryObject {
        private String name;
        private Integer minAge;
        private Integer maxAge;
        private Integer dormBuildId;
    }

    ■ 没有实现职责分离的情况:

        @Override
        public List<Teacher> query(TeacherQueryObject tqo) {
            StringBuilder sql = new StringBuilder();
            sql.append("SELECT * FROM t_teacher WHERE 1=1");
            //封装占位符参数
            List<Object> parameters = new ArrayList<>();

           // 拼接sql语句和设置占位符参数值
            //姓名
            if (StringUtils.isNotBlank(tqo.getName())) {
                sql.append(" AND name LIKE ?");
                parameters.add("%" + tqo.getName() + "%");
            }

      。。。。。

    }

    ■ 职责分离(谁拥有该数据,谁就应该包含操作该数据的方法):

    ❀ 要拼接的sql语句的数据时在tqo对象里的,且占位符的参数设置数据也是在tqo对象,则tqo对象应该提供对应的方法

    package com.shan.query;
    
    import java.util.ArrayList;
    import java.util.List;
    import org.apache.commons.lang3.StringUtils;
    import lombok.Data;
    
    @Data
    public class TeacherQueryObject {
        private String name;
        private Integer minAge;
        private Integer maxAge;
        private Integer dormBuildId;
    //    // 封装占位符参数
        private List<Object> parameters = new ArrayList<>();
        
        public TeacherQueryObject() {};
        public TeacherQueryObject(String name, Integer minAge, Integer maxAge, Integer dormBuildId) {
            this.name = name;
            this.minAge = minAge;
            this.maxAge = maxAge;
            this.dormBuildId = dormBuildId;
            this.parameters = parameters;
        }
            
        public String getQuery() {
            StringBuilder sql = new StringBuilder();
            sql.append(" WHERE 1=1");
            // 拼接姓名
            if (StringUtils.isNotBlank(name)) {
                sql.append(" AND name LIKE ?");        
                parameters.add("%" + name + "%");
            }
            // 拼接最小年龄
            if (minAge != null) {
                sql.append(" AND age >= ?");    
                parameters.add(minAge);
            }
            // 拼接最大年龄
            if (maxAge != null) {
                sql.append(" AND age <= ?");
                parameters.add(maxAge);
            }
            return sql.toString();
        }
        
        public List<Object> getParameters() {
            return parameters;
        }
    
    }
        // 高级查询
        @Override
        public List<Teacher> query(TeacherQueryObject tqo) {
            //职责分离【要拼接的sql语句的数据时在tqo对象里的,且占位符的参数设置数据也是在tqo对象,则tqo对象应该提供对应的方法】
            String querySql = tqo.getQuery();
            String sql = "select * from t_teacher" + querySql;
            List<Object> parameters = tqo.getParameters();
            System.out.println(querySql);
            System.out.println(parameters);
            return JdbcTemplate.query(sql, new BeanListHandler<>(Teacher.class), parameters.toArray());
        }

    本文来自博客园,作者:一乐乐,转载请注明原文链接:https://www.cnblogs.com/shan333/p/15715406.html

  • 相关阅读:
    jsoncpp使用
    java学习笔记12--国际化
    java学习笔记13--比较器(Comparable、Comparator)
    java学习笔记15--引用传递
    java学习笔记16--异常
    Java学习笔记——File类之文件管理和读写操作、下载图片
    java学习笔记3
    我的二十一天CoreJava 学习笔记
    大数据处理方面的 7 个开源搜索引擎
    GridView编辑删除操作
  • 原文地址:https://www.cnblogs.com/shan333/p/15715406.html
Copyright © 2020-2023  润新知