MyBatis動態(tài)SQL如何實現(xiàn)前端指定返回字段
動態(tài)SQL實現(xiàn)前端指定返回字段
問題描述
在使用ClickHouse時,遇到需要根據(jù)業(yè)務需求,動態(tài)返回指定字段,從而充分利用ClickHouse列式存儲的優(yōu)勢。
解決方案
可用MyBatis的動態(tài)SQL進行數(shù)據(jù)返回;故可在業(yè)務層將指定返回的列傳入數(shù)據(jù)層,利用foreach標簽進行遍歷返回數(shù)據(jù)。
代碼實現(xiàn)
1.請求參數(shù)
@Data
public class QueryDTO {
? ? /**
? ? ?* 返回值
? ? ?*/
? ? private Set<String> targetFields;
}2.mapper接口
?? ?/** ? ? ?* 查詢數(shù)據(jù) ? ? ?* @param record ? ? ?* @return ? ? ?*/ ? ? List<ResourceTotal> query(QueryDTO record);
3.mapper.xml實現(xiàn)
? <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.使用動態(tài)返回字段時,不可使用預先編譯,故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 指向一個文件,該文件為新建實體類,里面是要返回的 “部分字段”
? ? <!-- 全省設(shè)備數(shù)量統(tǒng)計 數(shù)據(jù)返回 --> ?? ?<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> ?? ? ?? ?<!-- 全省設(shè)備數(shù)量統(tǒng)計 --> ?? ?<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 文件內(nèi)容如下:
package com.sinosoft.pojo;
/**
?* 數(shù)據(jù)返回
?* @author zhangyajuan
?*
?*/
public class DeviceNumber {? ??
?? ?private String distCode;//行政區(qū)劃
?? ?private String distName;//行政區(qū)劃名稱
?? ?private String number;//設(shè)備數(shù)量?
?? ?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;
?? ?}
}以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
IDEA使用JDBC安裝配置jar包連接MySQL數(shù)據(jù)庫
這篇文章介紹了IDEA使用JDBC安裝配置jar包連接MySQL數(shù)據(jù)庫的方法,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-01-01
SpringBoot集成本地緩存性能之王Caffeine示例詳解
這篇文章主要為大家介紹了SpringBoot集成本地緩存性能之王Caffeine的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07
Java基礎(chǔ)之多線程方法狀態(tài)和創(chuàng)建方法
Java中可以通過Thread類和Runnable接口來創(chuàng)建多個線程,下面這篇文章主要給大家介紹了關(guān)于Java基礎(chǔ)之多線程方法狀態(tài)和創(chuàng)建方法的相關(guān)資料,需要的朋友可以參考下2021-09-09
詳解SpringBoot Controller接收參數(shù)的幾種常用方式
這篇文章主要介紹了詳解SpringBoot Controller接收參數(shù)的幾種常用方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-10-10
Spring?容器初始化?register?與?refresh方法
這篇文章主要介紹了Spring?容器初始化?register?與?refresh方法,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-07-07

