mybatis 中@SelectProvider注解的使用

news/2024/10/25 1:28:32/


我看了下与@Select有啥区别,这个@SelectProvider是能够加多条件判断的,看下面的代码示例:

@SelectProvider:用于构建动态查询SQL。
@InsertProvider:用于构建动态新增SQL。
@UpdateProvider:用于构建动态更新SQL。
@DeleteProvider:用于构建动态删除SQL。

 type为method对应的方法,其中参数与查询中的参数是一样的本例中都为QueryParam,method为type中对应的返回sql的方法
 @SelectProvider(type = SqlProvider.class, method = "count")
    int count(@Param("param") QueryParam param);
    
    
   class SqlProvider {

        public String list(QueryParam param) {
            return buildQueryParam(param, false);
        }

        public String count(QueryParam param) {
            return buildQueryParam(param, true);
        }

        private String toDate(Long timestamp) {
            SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
            String startTime = format.format(new Date(timestamp));
            return startTime;
        }

        private String buildQueryParam(QueryParam param, boolean queryCount) {
            StringBuilder sqlBuilder = new StringBuilder();
            sqlBuilder.append(" select ");
            sqlBuilder.append(queryCount ? " count(*) " : " " + FIELD + " ");
            sqlBuilder.append(" from " + TABLE + " where 1=1 ");
            if (StringUtils.isNotBlank(param.getId())) {
                sqlBuilder.append(" and transactionNum='" + param.getId() + "' ");
            }
            if (StringUtils.isNotBlank(param.getCustomerId())) {
                sqlBuilder.append(" and customerId='" + param.getCustomerId() + "' ");
            }
            if (param.getAssets() != null && param.getAssets().size() > 0) {
                String assets = String.join("','", param.getAssets());
                sqlBuilder.append(" and coinCode in ('" + assets + "') ");
            }
            if (null != param.getStartTime() && param.getStartTime() > 0) {
                sqlBuilder.append(" and created >= '" + toDate(param.getStartTime()) + "' ");
            }
            if (null != param.getEndTime() && param.getEndTime() > 0) {
                sqlBuilder.append(" and created <= '" + toDate(param.getEndTime()) + "' ");
            }
            if (null != param.getType()) {
                sqlBuilder.append(" and transactionType=" + param.getType().getType());
            }
            if (null != param.getStatuses() && param.getStatuses().size() > 0) {
                if (param.getStatuses().size() == 1) {
                    sqlBuilder.append(" and status=" + param.getStatuses().get(0).getStatus());
                } else {
                    sqlBuilder.append(" and status in (");
                    List<String> statusList = param.getStatuses().stream().map(s -> String.valueOf(s.getStatus())).collect(Collectors.toList());
                    String.join(",", statusList);
                    sqlBuilder.append(")");
                }
            }

            if (!queryCount) {
                sqlBuilder.append(" ORDER BY transactionNum DESC  ");

                if (null != param.getOffset() && null != param.getLimit()) {
                    sqlBuilder.append(" limit " + param.getOffset() + "," + param.getLimit());
                }
            }

            return sqlBuilder.toString();
        }

    }


http://www.ppmy.cn/news/5818.html

相关文章

Qt——基本介绍、详解对象树

目录 一.基本介绍 二.对象树 一.基本介绍 创建qt项目是&#xff0c;如果选择空窗口QWidget&#xff0c;那么mian函数中会有如下代码&#xff1a; #include "myWindow.h"#include <QApplication>int main(int argc, char *argv[]) {QApplication a(argc, ar…

Opencv(C++)笔记--直方图均衡化、直方图计算

目录 1--直方图均衡化 2--直方图计算 1--直方图均衡化 ① 简述&#xff1a; 对图片的对比度进行调整&#xff0c;输入为灰度图像&#xff0c;对亮度进行归一化处理&#xff0c;提高灰度图的对比度&#xff1b; ② Opencv API&#xff1a; cv::equalizeHist(gray, dst); ③…

公开竞价与封闭式竞价有什么不同?

电子竞价是电子采购的一种形式。电子采购是指通过信息和网络系统在线进行的招标采购过程。 电子竞价是指一种基于网络的系统&#xff0c;允许潜在供应商在网上实时竞争商品/服务的价格。电子竞价的使用方式类似于e-bay平台&#xff0c;出价最高者获胜。在建筑业&#xff0c;这…

多期DID和事件研究法含文献和do代码

多期DID和事件研究法含文献和do代码 1、方法&#xff1a;多期DID 2来源&#xff1a;JDE发表的一篇多期DID和事件研究法相关的文章&#xff0c; 文章名为为"Here waits the bride? The effect of Ethiopias child marriage law"。 3、数据内容&#xff1a;数据包…

Huffman二进制编码以及文本的压缩与解压

目录Huffman树转化成二进制编码文本压缩文本解压Huffman树转化成二进制编码 在上一篇博客的末尾&#xff0c;将Huffman树转化成了01 构成的字符串&#xff0c;显然在实际应用中不是这种操作。我们实际想要的是01构成的一串bits&#xff1b;举个例子&#xff1a;字符"A&quo…

Spring Cloud Alibaba Sentinel - - >流控规则初体验

源码地址&#xff1a;https://github.com/alibaba/Sentinel 新手指南&#xff1a;https://github.com/alibaba/Sentinel/wiki/新手指南#公网-demo 官方文档&#xff1a;https://sentinelguard.io/zh-cn/docs/introduction.html 注解支持文档&#xff1a;https://github.com/ali…

Android---Banner轮播图

轮播图是一种很常见的UI。Banner框架能够帮助我们快速开发&#xff0c;完成首页轮播图效果的需求。 1、导入Banner依赖 implementation io.github.youth5201314:banner:2.2.2 2、activity_main.xml布局。 banner_loop_time: 设置轮播间隔时间&#xff0c;默认3000&#xff…

基于注解方式Spring Security忽略拦截

文章目录1.Spring Security忽略拦截配置2.基于配置文件注入2.1.添加配置2.2.修改Spring Security配置类2.3. 测试3.基于注解的方式过滤接口3.1.添加注解3.2.获取所有使用了IgnoreWebSecurity注解的接口访问路径3.3.测试1.Spring Security忽略拦截配置 关于Spring Securite的使…