mybatis用pagehelper 然后用CountJSqlParser45,发现自己手写的mapper查询效率很慢

如题

效率慢

分页查询,发现效率很慢,然后发现是比较复杂的sql,CountJSqlParser45它不会帮忙优化掉,就是select多少字段它count的时候也还是这么多字段

框架里的用法是这样的

所以去看了CountJSqlParser45里面的代码,发现如果有group之类的,它就不帮忙把count优化一下,直接在外面套了一层count(0)

知道问题之后就是覆盖这个方法,所以在自己的下面新建了一个同路径同名的覆盖它

原来的代码是发现不是简单sql就直接不处理了,现在的逻辑是发现是PlainSelect但是不是isSimpleCount的情况下,把查询里面的select的普通字段都去除掉,新写了cleanSimpleField这个方法

逻辑很简单,如果是比较复杂的字段还留着,因为可能会影响结果,比如函数啊别名啊之类的,但是如果只是简单的字段都去掉,如果发现都是简单字段,那么直接用1来代替

c 复制代码
    public List<SelectItem> cleanSimpleField(PlainSelect select){

        //因为查询太多的话会导致速度很慢,所以移除掉普通的字段,把肯能影响结果的字段留下来
        List<SelectItem> newSelectItems =new ArrayList<>();

        //遍历原来的select 然后把需要的留下
        for (SelectItem item : select.getSelectItems()) {
            //select列中包含参数的时候不可以去掉,否则会引起参数个数错误
            if (item.toString().contains("?")) {
                newSelectItems.add(item);
            }
            //如果查询列中包含函数,也不可以,函数可能会聚合列
            if (item instanceof SelectExpressionItem) {
                Expression expression = ((SelectExpressionItem) item).getExpression();
                if (expression instanceof Function) {
                    String name = ((Function) expression).getName();
                    if (name != null) {
                        String NAME = name.toUpperCase();
                        if (skipFunctions.contains(NAME)) {
                            //go on
                        } else if (falseFunctions.contains(NAME)) {
                            newSelectItems.add(item);
                        } else {
                            for (String aggregateFunction : AGGREGATE_FUNCTIONS) {
                                if (NAME.startsWith(aggregateFunction)) {
                                    falseFunctions.add(NAME);
                                    newSelectItems.add(item);
                                }
                            }
                            skipFunctions.add(NAME);
                        }
                    }
                } else if (expression instanceof Parenthesis && ((SelectExpressionItem) item).getAlias() != null) {
                    //#555,当存在 (a+b) as c 时,c 如果出现了 order by 或者 having 中时,会找不到对应的列,
                    // 这里想要更智能,需要在整个SQL中查找别名出现的位置,暂时不考虑,直接排除
                    newSelectItems.add(item);
                }
            }
        }

        //都是简单的都被去掉了,那么就把原来的第一个拿来
        if (ObjectUtil.isEmpty(newSelectItems)){
            newSelectItems.add(new SelectExpressionItem(new Column("1")));
        }

        return newSelectItems;
    }

疑惑

照理说LocalMySqlDialect里面改成自己的新的类,不是CountJSqlParser45应该也行的,但是不知道为什么我把CountJSqlParser45改成自己新写的类不行,所以只能用覆盖的方式了

c 复制代码
this.countSqlParser = ClassUtil.newInstance(properties.getProperty("countSqlParser"), CountSqlParser.class, properties, CountJSqlParser45::new);
//改成下面这个不知道为什么不行
```c
this.countSqlParser = ClassUtil.newInstance(properties.getProperty("countSqlParser"), CountSqlParser.class, properties, MyCountJSqlParser45::new);
复制代码
相关推荐
唐僧洗头爱飘柔95275 小时前
【SSM-SSM整合】将Spring、SpringMVC、Mybatis三者进行整合;本文阐述了几个核心原理知识点,附带对应的源码以及描述解析
java·spring·mybatis·springmvc·动态代理·ioc容器·视图控制器
意倾城14 小时前
浅说MyBatis-Plus 的 saveBatch 方法
java·mybatis
Brilliant Nemo17 小时前
五、框架实战:SSM整合原理和实战
maven·mybatis
小赵面校招17 小时前
Spring Boot整合MyBatis全攻略:原理剖析与最佳实践
java·spring boot·mybatis
小赵面校招17 小时前
SpringBoot整合MyBatis-Plus:零XML实现高效CRUD
xml·spring boot·mybatis
悟空打码1 天前
MyBatis源码解读5(3.1、缓存简介)
缓存·mybatis
多多*1 天前
Java反射 八股版
java·开发语言·hive·python·sql·log4j·mybatis
Auc241 天前
OJ判题系统第4期之判题机模块架构——设计思路、实现步骤、代码实现(工厂模式、代理模式的实践)
java·spring cloud·log4j·mybatis·代理模式·工厂模式
佛祖让我来巡山2 天前
【Java持久层技术演进全解析】从JDBC到MyBatis再到MyBatis-Plus
mybatis·jdbc·mybatisplus·持久层框架
冼紫菜2 天前
【Spring Boot 多模块项目】@MapperScan失效、MapperScannerConfigurer 报错终极解决方案
java·开发语言·mybatis