国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

Mysql--Histore(Mybatis)批量查詢操作

2024-07-24 13:00:22
字體:
來源:轉載
供稿:網友

先從MySQL中查詢到mList

//分頁查詢車輛數據

Page<?> total = PageHelper.startPage(page, rows);

List<VehistoryVO> mlist=vehicleInfoMapper.queryVehDataForhi(param);

再次分頁查詢Histore,批量查詢,

Page<?> total = PageHelper.startPage(page, rows);

List<VehicleData> hList=vehicleDataMapper.queryBySeqs(mlist);

把hList查詢的數據set到mList中統一返回前臺

if(hList!=null){for(int i=0;i<mlist.size();i++){mlist.get(i).setData(hList.get(i));}}

------------------------------------------------service----------------------------------------------------------

------------------------------------------------VO----------------------------------------------------------

------------------------------------------------Mysql----------------------------------------------------------

------------------------------------------------Histore----------------------------------------------------------

======================批量查詢參數List類型---報錯參考如下===================

根據報錯日志分析,是MyBatis在解析xml時找不到其中聲明的studentNameList,但是在Dao中明明傳的參數就是studentNameList,怎么會報錯呢?

查詢了一下MyBatis官方的說明文檔,終于找到了原因,在http://mybatis.github.io/mybatis-3/zh/dynamic-sql.html#foreach里有一段說明:

寫道注意 你可以傳遞一個 List 實例或者數組作為參數對象傳給 MyBatis。當你這么做的時 候,MyBatis 會自動將它包裝在一個 Map 中,用名稱在作為鍵。List 實例將會以“list” 作為鍵,而數組實例將會以“array”作為鍵。

因為我傳的參數只有一個,而且傳入的是一個List集合,所以mybatis會自動封裝成Map<"list",studentNameList>。在解析的時候會通過“list”作為Map的key值去尋找。但是我在xml中卻聲明成studentNameList了,所以自然會報錯找不到。

 

解決辦法:

第一種就是修改mapper.xml中foreach標簽內容,把studentNameList修改為list

[html] view plain copy<if test="list != null">      AND student_name in      <foreach collection="list" item="item" open="(" separator="," close=")">          #{item}       </foreach>  </if>  

不過這種方式我個人不太建議,因為以后如果要擴展該方法,增加集合參數的時候,還得修改xml中的內容。

 

第二種方式,修改dao中的參數傳入方式,手動封裝成map,然后把map當參數傳進去

Dao方法修改為:

[java] view plain copypublic int getStudentCount(List<String> studentNameList){      //把參數手動封裝在Map中      Map<String, Object> map = new HashMap<String, Object>();      map.put("studentNameList", studentNameList);      return super.count("getStudentCount", map);  }  然后修改mapper.xml中的parameterType類型為Map

[html] view plain copy<!--注意下面的parameterType類型必須修改為Map類型,foreach中引用的List名稱不用改變-->  <select id="Student.getStudentCount" parameterType="java.util.Map" resultType="java.lang.Integer">      <![CDATA[     SELECT         COUNT(*)     FROM         t_student WHERE 1=1      ]]>      <if test="studentNameList != null">          AND student_name in          <foreach collection="studentNameList" item="item" open="(" separator="," close=")">              #{item}           </foreach>      </if>  </select>  
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 广河县| 江阴市| 商城县| 广水市| 绥化市| 正宁县| 武清区| 澄江县| 海城市| 新巴尔虎右旗| 彭州市| 手机| 鹿泉市| 丹阳市| 乐陵市| 左贡县| 洛浦县| 渝北区| 灵宝市| 东城区| 鄢陵县| 天峻县| 横山县| 龙山县| 巴彦县| 玉树县| 蒙阴县| 内丘县| 射洪县| 伊宁县| 彭阳县| 沁源县| 石泉县| 浏阳市| 宜黄县| 通道| 北安市| 进贤县| 哈巴河县| 东宁县| 崇仁县|