• Mybatis-plus 自定义SQL注入器查询@TableLogic 逻辑删除后的数据


    目录

    1  需求

    2  解决方案

    3  方案:

    3.1  方案1,继承 AbstractMethod拼接SQL语句

    3.2. 方案2,继承 AbstractMethod拼接SQL语句

    4.  自定义SQL注入器,注册上述自定义的方法

    5.  自定义基础mapper,声明注册的方法

    6. 使用声明的方法

    6.1  业务mapper继承自定义的CustomBaseMapper

    6.2 调用方法selectIgnoreLogicDelete

    6.3 调用方法selectIgnoreLogicDeleteByMap


    1  需求

    Mybatis-plus使用@TableLogic注解进行逻辑删除数据后,在某些场景下,又需要查询该数据时,又不想写SQL。

    2  解决方案

    自定义Mybatis-plus的SQL注入器一劳永逸的解决该问题

    3  方案:

    3.1  方案1,继承 AbstractMethod拼接SQL语句

    1. public class SelectIgnoreLogicDeleteByMap extends AbstractMethod {
    2. @Override
    3. public MappedStatement injectMappedStatement(Class mapperClass, Class modelClass, TableInfo tableInfo) {
    4. String sqlBase= "";
    5. String sqlScript = this.sqlWhereByMap(tableInfo);
    6. String sql = String.format(sqlBase, this.sqlSelectColumns(tableInfo, false), tableInfo.getTableName(), sqlScript);
    7. SqlSource sqlSource = this.languageDriver.createSqlSource(this.configuration, sql, Map.class);
    8. return this.addSelectMappedStatementForTable(mapperClass, "selectIgnoreLogicDeleteByMap", sqlSource, tableInfo);
    9. }
    10. /**
    11. * 拼接where条件根据map参数
    12. *
    13. * @param table 表
    14. * @return sql
    15. */
    16. protected String sqlWhereByMap(TableInfo table) {
    17. String sqlScript;
    18. sqlScript = SqlScriptUtils.convertChoose("v == null", " ${k} IS NULL ", " ${k} = #{v} ");
    19. sqlScript = SqlScriptUtils.convertForeach(sqlScript, "cm", "k", "v", "AND");
    20. sqlScript = SqlScriptUtils.convertWhere(sqlScript);
    21. sqlScript = SqlScriptUtils.convertIf(sqlScript, String.format("%s != null and !%s", "cm", "cm.isEmpty"), true);
    22. return sqlScript;
    23. }
    24. }

    3.2. 方案2,继承 AbstractMethod拼接SQL语句

    1. public class SelectIgnoreLogicDelete extends AbstractMethod {
    2. @Override
    3. public MappedStatement injectMappedStatement(Class mapperClass, Class modelClass, TableInfo tableInfo) {
    4. String sqlBase = "";
    5. String sql = String.format(sqlBase, this.sqlFirst(), this.sqlSelectColumns(tableInfo, true), tableInfo.getTableName(), this.sqlWhereEntityWrapper(true, tableInfo), this.sqlOrderBy(tableInfo), this.sqlComment());
    6. SqlSource sqlSource = this.languageDriver.createSqlSource(this.configuration, sql, modelClass);
    7. return this.addSelectMappedStatementForTable(mapperClass, "selectIgnoreLogicDelete", sqlSource, tableInfo);
    8. }
    9. /**
    10. * 拼接where条件
    11. *
    12. * @param newLine 新行
    13. * @param table 表
    14. * @return sql
    15. */
    16. protected String sqlWhereEntityWrapper(boolean newLine, TableInfo table) {
    17. String sqlScript = table.getAllSqlWhere(false, true, "ew.entity.");
    18. sqlScript = SqlScriptUtils.convertIf(sqlScript, String.format("%s != null", "ew.entity"), true);
    19. sqlScript = sqlScript + "\n";
    20. sqlScript = sqlScript + SqlScriptUtils.convertIf(String.format(SqlScriptUtils.convertIf(" AND", String.format("%s and %s", "ew.nonEmptyOfEntity", "ew.nonEmptyOfNormal"), false) + " ${%s}", "ew.sqlSegment"), String.format("%s != null and %s != '' and %s", "ew.sqlSegment", "ew.sqlSegment", "ew.nonEmptyOfWhere"), true);
    21. sqlScript = SqlScriptUtils.convertWhere(sqlScript) + "\n";
    22. sqlScript = sqlScript + SqlScriptUtils.convertIf(String.format(" ${%s}", "ew.sqlSegment"), String.format("%s != null and %s != '' and %s", "ew.sqlSegment", "ew.sqlSegment", "ew.emptyOfWhere"), true);
    23. sqlScript = SqlScriptUtils.convertIf(sqlScript, String.format("%s != null", "ew"), true);
    24. return newLine ? "\n" + sqlScript : sqlScript;
    25. }

    4.  自定义SQL注入器,注册上述自定义的方法

    1. public class CustomSqlInjector extends DefaultSqlInjector {
    2. @Override
    3. public List getMethodList(Class mapperClass, TableInfo tableInfo) {
    4. List methodList = super.getMethodList(mapperClass, tableInfo);
    5. methodList.add(new SelectIgnoreLogicDeleteByMap());
    6. methodList.add(new SelectIgnoreLogicDelete());
    7. return methodList;
    8. }
    9. }

    5.  自定义基础mapper,声明注册的方法

    1. public interface CustomBaseMapper extends BaseMapper {
    2. /**
    3. * 根据map条件查询数据,并忽略逻辑删除
    4. *
    5. * @param columnMap 查询条件
    6. * @return 结果信息
    7. */
    8. List selectIgnoreLogicDeleteByMap(@Param("cm") Map columnMap);
    9. /**
    10. * 根据条件查询数据,并忽略逻辑删除
    11. *
    12. * @param queryWrapper 查询条件
    13. * @return 结果信息
    14. */
    15. List selectIgnoreLogicDelete(@Param("ew") Wrapper queryWrapper);
    16. }

    6. 使用声明的方法

    6.1  业务mapper继承自定义的CustomBaseMapper

    1. @Mapper
    2. public interface UserMapper extends CustomBaseMapper {
    3. }

    6.2 调用方法selectIgnoreLogicDelete

    1. @Override
    2. public List getIgnoreDeleteById(Long userId) {
    3. LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();
    4. queryWrapper.eq(User::getId,userId);
    5. return this.baseMapper.selectIgnoreLogicDelete(queryWrapper);
    6. }

    6.3 调用方法selectIgnoreLogicDeleteByMap

    1. @Override
    2. public List getIgnoreDeleteById(Long userId) {
    3. Map columnMap = new HashMap<>(2);
    4. columnMap.put("id", userId);
    5. return this.baseMapper.selectIgnoreLogicDeleteByMap(columnMap);
    6. }

  • 相关阅读:
    楠姐技术漫话:图计算的那些事 | 京东云技术团队
    静态住宅代理的优缺点以及使用方法
    SpringBoot单元测试(unit testing)
    Windows编译Chrome浏览器【多图警告^-^】
    HarmonyOS NEXT应用开发—Grid和List内拖拽交换子组件位置
    思必驰周强:AI 和传统信号技术在实时音频通话中的应用
    怎样去除DataFrame字段列名
    什么是 Redis?
    吃鸡大作战:绝密攻略《揭秘吃鸡要领与细节,国际服全方位指南只在此!
    tailwindcss动态设置宽和高相等
  • 原文地址:https://blog.csdn.net/jinchunzhao123/article/details/127988188