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

com.github.wz2cool.dynamic.mybatis.mapper.SelectMaxByDynamicQueryMapper Maven / Gradle / Ivy

There is a newer version: 3.2.32
Show newest version
package com.github.wz2cool.dynamic.mybatis.mapper;

import com.github.wz2cool.dynamic.DynamicQuery;
import com.github.wz2cool.dynamic.helper.CommonsHelper;
import com.github.wz2cool.dynamic.lambda.*;
import com.github.wz2cool.dynamic.mybatis.TypeHelper;
import com.github.wz2cool.dynamic.mybatis.QueryHelper;
import com.github.wz2cool.dynamic.mybatis.mapper.constant.MapperConstants;
import com.github.wz2cool.dynamic.mybatis.mapper.provider.DynamicQueryProvider;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.SelectProvider;
import tk.mybatis.mapper.annotation.RegisterMapper;

import java.math.BigDecimal;
import java.util.Date;
import java.util.Optional;

/**
 * @author Frank
 */
@RegisterMapper
@SuppressWarnings("squid:S1214")
public interface SelectMaxByDynamicQueryMapper {

    QueryHelper QUERY_HELPER = new QueryHelper();

    /**
     * Select max value of column by dynamic query.
     *
     * @param column       the column need get max value
     * @param dynamicQuery dynamic query
     * @return max value of column.
     */
    @SelectProvider(type = DynamicQueryProvider.class, method = "dynamicSQL")
    Object selectMaxByDynamicQuery(
            @Param(MapperConstants.COLUMN) String column, @Param(MapperConstants.DYNAMIC_QUERY) DynamicQuery dynamicQuery);

    /**
     * Select max value of property by dynamic query.
     *
     * @param getPropertyFunction the property need get max value
     * @param dynamicQuery        dynamic query.
     * @return max value of property.
     */
    default  Object selectMaxByDynamicQueryInternal(
            GetPropertyFunction getPropertyFunction, DynamicQuery dynamicQuery) {
        String propertyName = CommonsHelper.getPropertyName(getPropertyFunction);
        Class entityClass = dynamicQuery.getEntityClass();
        String queryColumn = QUERY_HELPER.getQueryColumnByProperty(entityClass, propertyName);
        return selectMaxByDynamicQuery(queryColumn, dynamicQuery);
    }

    /**
     * Select max value of property by dynamic query.
     *
     * @param getPropertyFunction the property need get max value
     * @param dynamicQuery        dynamic query.
     * @return max value of property.
     */
    default Optional selectMaxByDynamicQuery(
            GetBigDecimalPropertyFunction getPropertyFunction, DynamicQuery dynamicQuery) {
        Object result = selectMaxByDynamicQueryInternal(getPropertyFunction, dynamicQuery);
        return Optional.ofNullable(TypeHelper.getBigDecimal(result));
    }

    /**
     * Select max value of property by dynamic query.
     *
     * @param getPropertyFunction the property need get max value
     * @param dynamicQuery        dynamic query.
     * @return max value of property.
     */
    default Optional selectMaxByDynamicQuery(
            GetBytePropertyFunction getPropertyFunction, DynamicQuery dynamicQuery) {
        Object result = selectMaxByDynamicQueryInternal(getPropertyFunction, dynamicQuery);
        return Optional.ofNullable(TypeHelper.getByte(result));
    }

    /**
     * Select max value of property by dynamic query.
     *
     * @param getPropertyFunction the property need get max value
     * @param dynamicQuery        dynamic query.
     * @return max value of property.
     */
    default Optional selectMaxByDynamicQuery(
            GetDatePropertyFunction getPropertyFunction, DynamicQuery dynamicQuery) {
        Object result = selectMaxByDynamicQueryInternal(getPropertyFunction, dynamicQuery);
        return Optional.ofNullable(TypeHelper.getDate(result));
    }

    /**
     * Select max value of property by dynamic query.
     *
     * @param getPropertyFunction the property need get max value
     * @param dynamicQuery        dynamic query.
     * @return max value of property.
     */
    default Optional selectMaxByDynamicQuery(
            GetDoublePropertyFunction getPropertyFunction, DynamicQuery dynamicQuery) {
        Object result = selectMaxByDynamicQueryInternal(getPropertyFunction, dynamicQuery);
        return Optional.ofNullable(TypeHelper.getDouble(result));
    }

    /**
     * Select max value of property by dynamic query.
     *
     * @param getPropertyFunction the property need get max value
     * @param dynamicQuery        dynamic query.
     * @return max value of property.
     */
    default Optional selectMaxByDynamicQuery(
            GetFloatPropertyFunction getPropertyFunction, DynamicQuery dynamicQuery) {
        Object result = selectMaxByDynamicQueryInternal(getPropertyFunction, dynamicQuery);
        return Optional.ofNullable(TypeHelper.getFloat(result));
    }

    /**
     * Select max value of property by dynamic query.
     *
     * @param getPropertyFunction the property need get max value
     * @param dynamicQuery        dynamic query.
     * @return max value of property.
     */
    default Optional selectMaxByDynamicQuery(
            GetIntegerPropertyFunction getPropertyFunction, DynamicQuery dynamicQuery) {
        Object result = selectMaxByDynamicQueryInternal(getPropertyFunction, dynamicQuery);
        return Optional.ofNullable(TypeHelper.getInteger(result));
    }

    /**
     * Select max value of property by dynamic query.
     *
     * @param getPropertyFunction the property need get max value
     * @param dynamicQuery        dynamic query.
     * @return max value of property.
     */
    default Optional selectMaxByDynamicQuery(
            GetLongPropertyFunction getPropertyFunction, DynamicQuery dynamicQuery) {
        Object result = selectMaxByDynamicQueryInternal(getPropertyFunction, dynamicQuery);
        return Optional.ofNullable(TypeHelper.getLong(result));
    }

    /**
     * Select max value of property by dynamic query.
     *
     * @param getPropertyFunction the property need get max value
     * @param dynamicQuery        dynamic query.
     * @return max value of property.
     */
    default Optional selectMaxByDynamicQuery(
            GetShortPropertyFunction getPropertyFunction, DynamicQuery dynamicQuery) {
        Object result = selectMaxByDynamicQueryInternal(getPropertyFunction, dynamicQuery);
        return Optional.ofNullable(TypeHelper.getShort(result));
    }

    /**
     * Select max value of property by dynamic query.
     *
     * @param getPropertyFunction the property need get max value
     * @param dynamicQuery        dynamic query.
     * @return max value of property.
     */
    default Optional selectMaxByDynamicQuery(
            GetStringPropertyFunction getPropertyFunction, DynamicQuery dynamicQuery) {
        Object result = selectMaxByDynamicQueryInternal(getPropertyFunction, dynamicQuery);
        return Optional.ofNullable(TypeHelper.getString(result));
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy