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

com.alilitech.integration.jpa.parameter.MybatisJpaDynamicSqlSource Maven / Gradle / Ivy

/**
 *    Copyright 2017-2020 the original author or authors.
 *
 *    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.alilitech.integration.jpa.parameter;

import com.alilitech.integration.jpa.EntityMetaDataRegistry;
import com.alilitech.integration.jpa.domain.Order;
import com.alilitech.integration.jpa.domain.Sort;
import com.alilitech.integration.jpa.meta.EntityMetaData;
import com.alilitech.integration.jpa.criteria.CriteriaBuilder;
import com.alilitech.integration.jpa.criteria.CriteriaQuery;
import com.alilitech.integration.jpa.criteria.Specification;
import com.alilitech.integration.jpa.criteria.expression.PredicateExpression;
import org.apache.ibatis.binding.MapperMethod;
import org.apache.ibatis.mapping.BoundSql;
import org.apache.ibatis.scripting.xmltags.DynamicSqlSource;
import org.apache.ibatis.scripting.xmltags.SqlNode;
import org.apache.ibatis.session.Configuration;

/**
 * 扩展DynamicSqlSource,主要是扩展一些参数信息和转换
 * @author Zhou Xiaoxiang
 * @since 1.0
 */
public class MybatisJpaDynamicSqlSource extends DynamicSqlSource {

    private Class domainType;

    public MybatisJpaDynamicSqlSource(Configuration configuration, SqlNode rootSqlNode) {
        super(configuration, rootSqlNode);
    }

    public MybatisJpaDynamicSqlSource(Configuration configuration, SqlNode rootSqlNode, Class domainType) {
        super(configuration, rootSqlNode);
        this.domainType = domainType;
    }

    @Override
    public BoundSql getBoundSql(Object parameterObject) {
        //转换排序参数
        if(parameterObject instanceof Sort && domainType != null) {
            Sort sort = (Sort) parameterObject;
            for(Order order : sort.getOrders()) {
                EntityMetaData entityMetaData = EntityMetaDataRegistry.getInstance().get(domainType);
                String columnName = entityMetaData.getColumnMetaDataMap().get(order.getProperty()).getColumnName();
                order.setProperty(columnName);
            }
        } else if(parameterObject instanceof MapperMethod.ParamMap && domainType != null) {
            MapperMethod.ParamMap paramMap = (MapperMethod.ParamMap) parameterObject;
            paramMap.forEach((key, value) -> {
                if(value instanceof Sort) {
                    Sort sort = (Sort) value;
                    for(Order order : sort.getOrders()) {
                        EntityMetaData entityMetaData = EntityMetaDataRegistry.getInstance().get(domainType);
                        if(entityMetaData.getColumnMetaDataMap().containsKey(order.getProperty())) {
                            String columnName = entityMetaData.getColumnMetaDataMap().get(order.getProperty()).getColumnName();
                            order.setProperty(columnName);
                        }
                    }
                }
            });
        }

        //转换规格查询参数
        if(parameterObject instanceof Specification && domainType != null) {
            Specification specification = (Specification) parameterObject;

            CriteriaBuilder cb = new CriteriaBuilder(domainType);

            CriteriaQuery query = new CriteriaQuery(domainType);

            PredicateExpression predicate = specification.toPredicate(cb, query);

            if(predicate != null) {
                query.where(predicate);
            }
            parameterObject = query;
        }

        //System.out.println("MybatisJpaDynamicSqlSource");
        return super.getBoundSql(parameterObject);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy