使用(Java)变量或方法的结果替换到mapper文件中

使用(Java)变量或方法的结果替换到mapper文件中

方法

mapper.xml

<sql id="selectUserVo">
    select
    <bind name="initSql" value="'u.id,u.name,u.password,u.sex'"/>
    /*  会调用com.rikylinz.utils.SqlUtils类的resultFields方法 传入params参数和initSql参数 返回最新sql字段列表 */
    ${@com.rikylinz.utils.SqlUtils@resultFields(params,initSql)}
    from user u
</sql>

注意:params为对应 select组件的入参参数,initSql是自己定义的变量(可以根据自身进行优化)

java代码

/**
 * @author rikylinz
 * @description SQL中相关操作工具类
 * @date 2022/11/11 11:44
 */
public class SqlUtils {

    /**
     *  查询语句 返回字段列表
     *  与 mapper.xml中的 ${@com.rikylinz.utils.SqlUtils@resultFields(params,initSql)}格式配合使用
     * @param params        入参params
     * @param initSql       查询语句的完整字段列表
     * @return 最新字段列表
     */
    public static String resultFields(Map<String, Object> params, String initSql){
        List<String> includeFields = (List<String>) params.get("includeFields");
        List<String> excludeFields = (List<String>) params.get("excludeFields");

        String newSql = Stream.of(initSql.split(",")).filter(field -> {
            if(includeFields != null && !includeFields.isEmpty()){
                String newField;
                if(field.contains(".")){
                    newField = field.substring(field.indexOf(".") + 1);
                }else{
                    newField = field;
                }
                return includeFields.contains(newField);
            }
            return true;
        }).filter(field -> {
            if(excludeFields != null && !excludeFields.isEmpty()){
                String newField;
                if(field.contains(".")){
                    newField = field.substring(field.indexOf(".") + 1);
                }else{
                    newField = field;
                }
                return !excludeFields.contains(newField);
            }
            return true;
        }).collect(Collectors.joining(","));
        return newSql;
    }
}

扩展

  • 可以放入if标签的test属性中,其他类似,

    <if test="@com.rikylinz.utils.SqlUtils@resultFields(params)">
    </if>
    

变量

推测与方法使用一致,但未进行测试

以取别名为例

mapper.xml

<select>
	select count(*) from user ${@com.rikylinz.utils.SqlUtils@alias}
</select>

java代码

/**
 * @author rikylinz
 * @description SQL中相关操作工具类
 * @date 2022/11/11 11:44
 */
public class SqlUtils {

    public static final String alias = "u";
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值