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图形界面超实用使用教程

    Java图形界面超实用使用教程

    在Java编程中图形界面应用程序是非常常见和重要的一部分,下面这篇文章主要给大家介绍了关于Java图形界面的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-01-01
  • IDEA使用JDBC安装配置jar包连接MySQL数据库

    IDEA使用JDBC安装配置jar包连接MySQL数据库

    这篇文章介绍了IDEA使用JDBC安装配置jar包连接MySQL数据库的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-01-01
  • SpringBoot集成本地缓存性能之王Caffeine示例详解

    SpringBoot集成本地缓存性能之王Caffeine示例详解

    这篇文章主要为大家介绍了SpringBoot集成本地缓存性能之王Caffeine的示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • java SpringMvc中拦截器的应用

    java SpringMvc中拦截器的应用

    大家好,本篇文章主要讲的是java SpringMvc中拦截器的应用,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-01-01
  • Java基础之多线程方法状态和创建方法

    Java基础之多线程方法状态和创建方法

    Java中可以通过Thread类和Runnable接口来创建多个线程,下面这篇文章主要给大家介绍了关于Java基础之多线程方法状态和创建方法的相关资料,需要的朋友可以参考下
    2021-09-09
  • 详解SpringBoot Controller接收参数的几种常用方式

    详解SpringBoot Controller接收参数的几种常用方式

    这篇文章主要介绍了详解SpringBoot Controller接收参数的几种常用方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • Spring 容器初始化 register 与 refresh方法

    Spring 容器初始化 register 与 refresh方法

    这篇文章主要介绍了Spring 容器初始化 register 与 refresh方法,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-07-07
  • 关于webLucene 安装方法

    关于webLucene 安装方法

    webLucene是一个基于开源项目lucene实现站内搜索的工具,关于它的安装,百度得到的大多是一样的,按照步骤也能正确安装并运行,需要注意的问题是
    2009-06-06
  • SpringMVC方法返回值多种情况代码实例

    SpringMVC方法返回值多种情况代码实例

    这篇文章主要介绍了SpringMVC方法返回值多种情况代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • javaweb配置jsp路径映射操作

    javaweb配置jsp路径映射操作

    这篇文章主要介绍了javaweb配置jsp路径映射操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08

最新评论