Mybatis 動態獲取字段值(不需要創建javabean)


最近遇到一個這樣的需求,如下:

用戶可以通過自定義模板選擇需要查詢顯示的字段,需要動態查詢顯示。

 

前提:數據庫有一張表,里面有400多個字段。

要求:用戶在前台可以自定義模板,一個模板可能對應x個字段,自定義完成(比如自定義了一個名字為 RNC話務模型),用戶點擊RNC話務模型,需要查詢出來剛才自定義的那些字段的數據。

 

技術實現:用mybatis做數據層 (mybatis查詢原理:查詢出來的數據會封裝為一個map,將字段名作為key值,數據作為value值)

 

具體實現:

mybatis.xml配置如下:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"  

"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="com.huawei.galaxy.mybatis.dao.IDeepInsightGetDataMapper">

<select id="queryFlowData" parameterType="Map" resultType="Map"

        <![CDATA[ 

               SELECT * FROM TABLE

]]>

WHERE 1 = 1

<if test="param!= null and  param != '' ">

.........................

</if>

</select>

</mapper>

dao層接口定義:

public interface IDeepInsightGetDataMapper extends IBenchMarkMapper {

/**

* 功能:查詢流量高地數據

* @param param 傳遞參數

* @return

*/

public List<Map<String, Object>> queryFlowData(Map<String,Object> param);

}

 

service層接口定義:

public interface IDeepInsightService {

public List<List<Object>> getData(Map<String,Object> paramMap,TableParam pageParam);

}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM