MyBatis动态SQL如何实现前端指定返回字段

 更新时间:2022年01月25日 17:20:48   作者:iSetYu  
这篇文章主要介绍了MyBatis动态SQL如何实现前端指定返回字段,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

动态SQL实现前端指定返回字段

问题描述

在使用ClickHouse时,遇到需要根据业务需求,动态返回指定字段,从而充分利用ClickHouse列式存储的优势。

解决方案

可用MyBatis的动态SQL进行数据返回;故可在业务层将指定返回的列传入数据层,利用foreach标签进行遍历返回数据。

代码实现

1.请求参数

@Data
public class QueryDTO {
    /**
     * 返回值
     */
    private Set<String> targetFields;
}

2.mapper接口

    /**
     * 查询数据
     * @param record
     * @return
     */
    List<ResourceTotal> query(QueryDTO record);

3.mapper.xml实现

  <sql id="Base_Result_Column">
    resourceId, platformCount, createUserId
  </sql>
  <select id="query" parameterType="cn.example.module.data.test.QueryDTO" resultMap="BaseResultMap">
    select
    <foreach collection="targetFields" item="item" separator=",">
      ${item}
    </foreach>
    ,
    <include refid="Base_Result_Column"/>
    from resource_total
    where 1 = 1
  </select>

4.注意事项

a.使用动态返回字段时,不可使用预先编译,故foreach中使用‘$’符号,而不使用‘#’;

b.foreach标签后若还有其他固定字段返回,记得用逗号‘,’分隔。 

MyBatis如何返回部分字段

mybatis 返回部分字段,这里介绍两种方式(主推第一种) 

.xml文件中resultMap的type改为

java.util.HashMap 即可

其余代码都不用写, 亲测可用,xml文件中代码如下:

    <!-- 返回类型  -->
    <resultMap id="testRestMap" type="java.util.HashMap">
         <result column="province_name" jdbcType="VARCHAR" property="provinceName" />
         <result column="area_name" jdbcType="VARCHAR" property="areaName" />
         <result column="lane_num" jdbcType="VARCHAR" property="laneNum" />
         <result column="road_name" jdbcType="VARCHAR" property="roadName" />
    </resultMap>
    
    <!--sql查询  -->
    <select id="selTest"  resultMap="testRestMap">
        select 
            province_name,
            area_name,lane_num,
            road_name 
        from  site_info
        where 1=1
        and del_flag='0'
    </select>

第二种很笨的方法

重新新建一个对象实体,该实体文件的字段与要返回的 “部分字段” 一一对应即可,代码如下:

resultMap 的type=com.sinosoft.pojo.DeviceNumber   指向一个文件,该文件为新建实体类,里面是要返回的 “部分字段”

    <!-- 全省设备数量统计 数据返回 -->
    <resultMap id="DeviceNumber" type="com.sinosoft.pojo.DeviceNumber">
         <result column="distCode" jdbcType="VARCHAR" property="distCode" />
         <result column="distName" jdbcType="VARCHAR" property="distName" />
         <result column="number" jdbcType="VARCHAR" property="number" />
    </resultMap>
    
    <!-- 全省设备数量统计 -->
    <select id="statisticsDevice"  resultMap="DeviceNumber">
        SELECT
            t1.distCode,
            t1.distName,
            t2.number
        FROM
            (
            select 
                fd_objectid distCode,
                area_name  distName
            FROM t_sys_area 
            WHERE LEVEL='2'
        ) t1 LEFT JOIN (
            SELECT 
                city_no,
                count(*) as number 
            FROM site_info 
            WHERE 1=1
            and del_flag='0'
            and is_bridge!='1'
            GROUP BY city_no
        )t2 on t2.city_no=t1.distCode
    </select>

DeviceNumber 文件内容如下:

package com.sinosoft.pojo;
/**
 * 数据返回
 * @author zhangyajuan
 *
 */
public class DeviceNumber {    
    private String distCode;//行政区划
    private String distName;//行政区划名称
    private String number;//设备数量 
    public String getDistCode() {
        return distCode;
    }
    public void setDistCode(String distCode) {
        this.distCode = distCode;
    }
    public String getDistName() {
        return distName;
    }
    public void setDistName(String distName) {
        this.distName = distName;
    }
    public String getNumber() {
        return number;
    }
    public void setNumber(String number) {
        this.number = number;
    }
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java JDBC API介绍与实现数据库连接池流程

    Java JDBC API介绍与实现数据库连接池流程

    JDBC是指Java数据库连接,是一种标准Java应用编程接口( JAVA API),用来连接 Java 编程语言和广泛的数据库。从根本上来说,JDBC 是一种规范,它提供了一套完整的接口,允许便携式访问到底层数据库,本篇文章我们来了解JDBC API及数据库连接池
    2022-12-12
  • Java教程package和import访问控制的步骤详解

    Java教程package和import访问控制的步骤详解

    这篇文章主要为大家介绍了Java教程package和import访问控制的步骤详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • Mybatis调用Oracle存储过程的方法图文详解

    Mybatis调用Oracle存储过程的方法图文详解

    这篇文章主要介绍了Mybatis调用Oracle存储过程的方法介绍,需要的朋友可以参考下
    2017-09-09
  • Java实现多文件压缩加密并重命名压缩文件对象的方法

    Java实现多文件压缩加密并重命名压缩文件对象的方法

    这篇文章主要介绍了Java实现多文件压缩加密并重命名压缩文件对象的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • StringBuilder为什么线程不安全深入讲解

    StringBuilder为什么线程不安全深入讲解

    这篇文章主要给大家介绍了关于StringBuilder为什么线程不安全的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用StringBuilder线程具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • Java语言简介(动力节点Java学院整理)

    Java语言简介(动力节点Java学院整理)

    Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征,下面通过本文给大家分享java语言的简介,感兴趣的朋友一起看看吧
    2017-03-03
  • springboot(thymeleaf)中th:field和th:value的区别及说明

    springboot(thymeleaf)中th:field和th:value的区别及说明

    这篇文章主要介绍了springboot(thymeleaf)中th:field和th:value的区别及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • java 中http请求为了防止乱码解决方案

    java 中http请求为了防止乱码解决方案

    这篇文章主要介绍了java 中http请求为了防止乱码解决方案的相关资料,需要的朋友可以参考下
    2017-02-02
  • springSecurity用户认证和授权的实现

    springSecurity用户认证和授权的实现

    Spring Security 是一个开源的安全框架,提供了基于权限的访问控制、身份认证的功能,本文主要介绍了springSecurity用户认证和授权,具有一定参考价值,感兴趣的可以了解一下
    2024-04-04
  • 详解springboot启动时是如何加载配置文件application.yml文件

    详解springboot启动时是如何加载配置文件application.yml文件

    这篇文章主要介绍了详解springboot启动时是如何加载配置文件application.yml文件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06

最新评论