All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.baomidou.mybatisplus.extension.plugins.pagination.optimize.JsqlParserCountOptimize Maven / Gradle / Ivy

/*
 * Copyright (c) 2011-2014, hubin ([email protected]).
 * 

* Licensed under the Apache License, Version 2.0 (the "License"); you may not * use this file except in compliance with the License. You may obtain a copy of * the License at *

* http://www.apache.org/licenses/LICENSE-2.0 *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations under * the License. */ package com.baomidou.mybatisplus.extension.plugins.pagination.optimize; import java.util.ArrayList; import java.util.List; import org.apache.ibatis.logging.Log; import org.apache.ibatis.logging.LogFactory; import org.apache.ibatis.reflection.MetaObject; import com.baomidou.mybatisplus.core.parser.ISqlParser; import com.baomidou.mybatisplus.core.parser.SqlInfo; import com.baomidou.mybatisplus.core.toolkit.CollectionUtils; import com.baomidou.mybatisplus.extension.toolkit.SqlParserUtils; import net.sf.jsqlparser.expression.Expression; import net.sf.jsqlparser.expression.Function; import net.sf.jsqlparser.expression.LongValue; import net.sf.jsqlparser.expression.operators.relational.ExpressionList; import net.sf.jsqlparser.parser.CCJSqlParserUtil; import net.sf.jsqlparser.statement.select.Distinct; import net.sf.jsqlparser.statement.select.OrderByElement; import net.sf.jsqlparser.statement.select.PlainSelect; import net.sf.jsqlparser.statement.select.Select; import net.sf.jsqlparser.statement.select.SelectExpressionItem; import net.sf.jsqlparser.statement.select.SelectItem; /** *

* JsqlParser Count Optimize *

* * @author hubin * @since 2017-06-20 */ public class JsqlParserCountOptimize implements ISqlParser { /** * 日志 */ private final Log logger = LogFactory.getLog(JsqlParserCountOptimize.class); private static final List COUNT_SELECT_ITEM = countSelectItem(); @Override public SqlInfo parser(MetaObject metaObject, String sql) { if (logger.isDebugEnabled()) { logger.debug(" JsqlParserCountOptimize sql=" + sql); } SqlInfo sqlInfo = SqlInfo.newInstance(); try { Select selectStatement = (Select) CCJSqlParserUtil.parse(sql); PlainSelect plainSelect = (PlainSelect) selectStatement.getSelectBody(); Distinct distinct = plainSelect.getDistinct(); List groupBy = plainSelect.getGroupByColumnReferences(); List orderBy = plainSelect.getOrderByElements(); // 添加包含groupBy 不去除orderBy if (CollectionUtils.isEmpty(groupBy) && CollectionUtils.isNotEmpty(orderBy)) { plainSelect.setOrderByElements(null); sqlInfo.setOrderBy(false); } //#95 Github, selectItems contains #{} ${}, which will be translated to ?, and it may be in a function: power(#{myInt},2) for (SelectItem item : plainSelect.getSelectItems()) { if (item.toString().contains("?")) { return sqlInfo.setSql(SqlParserUtils.getOriginalCountSql(selectStatement.toString())); } } // 包含 distinct、groupBy不优化 if (distinct != null || CollectionUtils.isNotEmpty(groupBy)) { return sqlInfo.setSql(SqlParserUtils.getOriginalCountSql(selectStatement.toString())); } // 优化 SQL plainSelect.setSelectItems(COUNT_SELECT_ITEM); return sqlInfo.setSql(selectStatement.toString()); } catch (Throwable e) { // 无法优化使用原 SQL return sqlInfo.setSql(SqlParserUtils.getOriginalCountSql(sql)); } } /** *

* 获取jsqlparser中count的SelectItem *

*/ private static List countSelectItem() { Function function = new Function(); function.setName("COUNT"); List expressions = new ArrayList<>(); LongValue longValue = new LongValue(1); ExpressionList expressionList = new ExpressionList(); expressions.add(longValue); expressionList.setExpressions(expressions); function.setParameters(expressionList); List selectItems = new ArrayList<>(); SelectExpressionItem selectExpressionItem = new SelectExpressionItem(function); selectItems.add(selectExpressionItem); return selectItems; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy