解決Mybatis的@Param()注解導(dǎo)致分頁(yè)失效的問(wèn)題
@Param注解導(dǎo)致分頁(yè)失效—分頁(yè)攔截器
問(wèn)題描述在使用mybatis分頁(yè)時(shí),使用@Param注解傳入了兩個(gè)對(duì)象,分頁(yè)失效,查詢出的總是全部的數(shù)據(jù)。出現(xiàn)問(wèn)題時(shí),分頁(yè)策略為:分頁(yè)攔截器實(shí)現(xiàn)的分頁(yè)【錯(cuò)誤寫(xiě)法】
service寫(xiě)法:
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 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>原因解析
【關(guān)鍵原因】
根源問(wèn)題在于:在PaginationInterceptor中,分頁(yè)對(duì)象Page被解析為null,導(dǎo)致的分頁(yè)失效 由于@Param會(huì)將參數(shù)封裝到ParamMap中,而page對(duì)象在實(shí)體類(lèi)entity中,導(dǎo)致convertParameter方法返回的page對(duì)象為null【mybatis原碼:@Param將參數(shù)封裝到ParamMap】
跟蹤源碼進(jìn)入:org.apache.ibatis.binding.MapperMethod.class
進(jìn)入executeForMany方法:
進(jìn)入convertArgsToSqlCommandParam方法,可以看到參數(shù)封裝到ParamMap中:
到此這篇關(guān)于解決Mybatis的@Param()注解導(dǎo)致分頁(yè)失效的問(wèn)題的文章就介紹到這了,更多相關(guān)Mybatis分頁(yè)失效內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. MySQL中查詢json格式的字段實(shí)例詳解2. Mariadb數(shù)據(jù)庫(kù)主從復(fù)制同步配置過(guò)程實(shí)例3. 如何:創(chuàng)建和運(yùn)行 CLR SQL Server 用戶定義的函數(shù)4. 用SQL語(yǔ)句查找Access中某表是否存在的小技巧5. Microsoft Office Access將單元格效果設(shè)置為凸起的方法6. MySQL中 and or 查詢的優(yōu)先級(jí)分析7. SQL SERVER2000中訂閱與發(fā)布的具體操作8. 解決Oracle模擬事務(wù)提交、表鎖,處理表鎖問(wèn)題9. Microsoft Office Access添加外鍵的方法10. 詳解MySQL InnoDB存儲(chǔ)引擎的內(nèi)存管理
