解決Mybatis的@Param()註解導致分頁失效的問題

@Param註解導致分頁失效—分頁攔截器

問題描述

在使用mybatis分頁時,使用@Param註解傳入瞭兩個對象,分頁失效,查詢出的總是全部的數據。

出現問題時,分頁策略為:分頁攔截器實現的分頁

錯誤寫法】

service寫法:

public Page<Entity> getByNidAndEntity(Page<Entity> page,String nid,Entity entity){
       entity.setPage(page);
       page.setList(dao.getByNidAndEntity(nid,entity));
       return page;
}

dao方法聲明:

List<Entity> getByNidAndEntity(@Param("nid") String nid,@Param("entity")Entity entity);

mapper.xml中的sql:

<select id="getByNidAndEntity" resultType="Entity">
      select <include refid="entityColumns" />
      from entity_table et left join other_table ot on et.id = ot.eid
      where ot.nid = #{nid} 
      and et.name = #{entity.name} and et.remarks = #{entity.remarks}
</select>

原因解析

關鍵原因】

  • 根源問題在於:在PaginationInterceptor中,分頁對象Page被解析為null,導致的分頁失效
  • 由於@Param會將參數封裝到ParamMap中,而page對象在實體類entity中,導致convertParameter方法返回的page對象為null

在這裡插入圖片描述

mybatis原碼:@Param將參數封裝到ParamMap】

跟蹤源碼進入:org.apache.ibatis.binding.MapperMethod.class

在這裡插入圖片描述

進入executeForMany方法:

在這裡插入圖片描述

進入convertArgsToSqlCommandParam方法,可以看到參數封裝到ParamMap中:

在這裡插入圖片描述

解決辦法

  • 不使用@Param註解:在傳遞多個參數(或是多個javaBean)時,可以使用一個包含page屬性的實體類進行封裝
  • 使用@Param註解:根據需求修改BaseInterceptor類中的convertParameter方法,使得解析page對象不為null即可

到此這篇關於解決Mybatis的@Param()註解導致分頁失效的問題的文章就介紹到這瞭,更多相關Mybatis分頁失效內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀:

    None Found