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

com.easy.query.api4j.select.extension.queryable5.SQLOrderable5 Maven / Gradle / Ivy

There is a newer version: 2.3.3
Show newest version
package com.easy.query.api4j.select.extension.queryable5;

import com.easy.query.api4j.select.Queryable5;
import com.easy.query.api4j.sql.SQLOrderBySelector;
import com.easy.query.api4j.sql.impl.SQLOrderByColumnSelectorImpl;
import com.easy.query.core.common.tuple.Tuple5;
import com.easy.query.core.expression.lambda.SQLExpression1;
import com.easy.query.core.expression.lambda.SQLExpression5;

/**
 * create time 2023/8/18 09:43
 * 文件说明
 *
 * @author xuejiaming
 */
public interface SQLOrderable5 extends ClientQueryable5Available, Queryable5Available {

    default Queryable5 orderByAsc(SQLExpression5, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector> selectExpression) {
        getClientQueryable5().orderByAsc((selector1, selector2, selector3, selector4, selector5) -> {
            selectExpression.apply(new SQLOrderByColumnSelectorImpl<>(selector1), new SQLOrderByColumnSelectorImpl<>(selector2), new SQLOrderByColumnSelectorImpl<>(selector3), new SQLOrderByColumnSelectorImpl<>(selector4), new SQLOrderByColumnSelectorImpl<>(selector5));
        });
        return getQueryable5();
    }

    default Queryable5 orderByAsc(boolean condition, SQLExpression5, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector> selectExpression) {
        getClientQueryable5().orderByAsc(condition, (selector1, selector2, selector3, selector4, selector5) -> {
            selectExpression.apply(new SQLOrderByColumnSelectorImpl<>(selector1), new SQLOrderByColumnSelectorImpl<>(selector2), new SQLOrderByColumnSelectorImpl<>(selector3), new SQLOrderByColumnSelectorImpl<>(selector4), new SQLOrderByColumnSelectorImpl<>(selector5));
        });
        return getQueryable5();
    }

    default Queryable5 orderByAscMerge(SQLExpression1, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector>> selectExpression) {
        return orderByAscMerge(true, selectExpression);
    }

    default Queryable5 orderByAscMerge(boolean condition, SQLExpression1, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector>> selectExpression) {
        return orderByAsc(condition, (t1, t2, t3, t4, t5) -> {
            selectExpression.apply(new Tuple5<>(t1, t2, t3, t4, t5));
        });
    }

    default Queryable5 orderByDesc(SQLExpression5, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector> selectExpression) {
        return orderByDesc(true, selectExpression);
    }

    default Queryable5 orderByDesc(boolean condition, SQLExpression5, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector> selectExpression) {
        getClientQueryable5().orderByDesc(condition, (selector1, selector2, selector3, selector4, selector5) -> {
            selectExpression.apply(new SQLOrderByColumnSelectorImpl<>(selector1), new SQLOrderByColumnSelectorImpl<>(selector2), new SQLOrderByColumnSelectorImpl<>(selector3), new SQLOrderByColumnSelectorImpl<>(selector4), new SQLOrderByColumnSelectorImpl<>(selector5));
        });
        return getQueryable5();
    }

    default Queryable5 orderByDescMerge(SQLExpression1, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector>> selectExpression) {
        return orderByDescMerge(true, selectExpression);
    }

    default Queryable5 orderByDescMerge(boolean condition, SQLExpression1, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector, SQLOrderBySelector>> selectExpression) {
        return orderByDesc(condition, (t1, t2, t3, t4, t5) -> {
            selectExpression.apply(new Tuple5<>(t1, t2, t3, t4, t5));
        });
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy