Spring Boot mybatis 配合 provider 使用

provider 可以动态生成 sql

在处理复杂逻辑而又不能使用存储过程的时候有很大优势

Mapper 中配置

@UpdateProvider(type = MerchantProvider.class, method = "updateSalesman")
void updateSalesman(@Param("M") MerchantSalesDTO merchantSalesDTO);

Provider 中配置

import com.icekredit.merchant.entity.DTO.MerchantDTO;
import com.icekredit.merchant.entity.DTO.MerchantSalesDTO;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.jdbc.SQL;

/**
 * Created by johnzh on
 * 2017/4/27. 10:01
 */
public class MerchantProvider {
    public String updateSalesman(@Param("M") MerchantSalesDTO merchantSalesDTO){
        SQL sql = new SQL(){{
            UPDATE("merchant_sales");

            if (merchantSalesDTO.getSalesName() != null){
                SET("sales_name = #{M.salesName}");
            }
            if (merchantSalesDTO.getUpper() != null){
                SET("upper = #{M.upper}");
            }
            WHERE("sales_id = #{M.salesId}");
        }};
        return sql.toString();
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1. 简介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的...
    笨鸟慢飞阅读 6,174评论 0 4
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,368评论 19 139
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,670评论 11 349
  • 数据分析的作用和对应的分析方法 对比分析法分为静态比较和动态比较两类静态:比较同一时间下对不同指标的比较,也叫横比...
    jlnbda3488375阅读 730评论 0 0
  • 算是新年第一弹, 没什么新鲜的, 继续做个"小码农" 目录 tmux是什么 tmux中的概念 session使用 ...
    诺之林阅读 906评论 0 0

友情链接更多精彩内容