mybatis-plus 自定义UpdateWrapper(二)实现列的case set

前言

小编在crud业务中会遇到case set的场景,

update `TD_XXX`
set
`status` = case `id` 
	when 12 Then 1 
	when 13 Then 2 
	when 14 Then 1 
end
where `id` in (12,13,14)

一般来说都是写在xml中,但是其实mybatis-plus也可以

<dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.0.1</version>
        </dependency>

源码分析

此部分跳过,在mybatis-plus 自定义UpdateWrapper(一)实现列自增 已经有详细描述了

思路

此时应该将sql分开看得清楚些

SET `columns` = (
     CASE `caseColumns` 
     	WHEN caseMap.keys[0] THEN caseMap.values[0]
   
     END
  )

代码实现

/**
     * 根据传入map case update 最终实现如下效果
     * <p>
     *      SET `columns` = (
     *     CASE `caseColumns` WHEN caseMap.keys[0] THEN caseMap.values[0]
     *     WHEN caseMap.keys[1] THEN caseMap.values[1]
     *     WHEN caseMap.keys[2] THEN caseMap.values[2]
     *     END)
     * </p>
     */
    public MyLambdaUpdateWrapper<T> caseSet(SFunction<T, ?> columns, Map<Object,Object> caseMap, SFunction<T, ?> caseColumns) {
        String columnsToString = super.columnToString(columns);

        List<Object> params = new ArrayList<>();
        StringBuilder stringBuilder = new StringBuilder();
        int paramIndex = 0;
        for (Object o : caseMap.keySet()) {
            stringBuilder.append(String.format("WHEN {%d} THEN {%d}", paramIndex++, paramIndex++)).append("\n");
            params.add(o);
            params.add(caseMap.get(o));
        }

        String caseSqlFormat = String.format("(case %s %s end)", super.columnToString(caseColumns), stringBuilder.toString());


        String format = String.format("%s =  %s", columnsToString, formatSql(caseSqlFormat, params.toArray(new Object[0])));


        setSql(format);

        return this;
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值