淺談sql_@SelectProvider及使用注意說(shuō)明
sql_@SelectProvider及使用注意
@Documented @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface SelectProvider { Class<?> type(); String method(); }
RoleDao.java
public interface RoleDao { @SelectProvider(type=RoleProvider.class,method="queryRolesByParamsSql") List<Role> queryRolesByParams(RoleQuery roleQuery); }
RoleProvider.java
public class RoleProvider { public String queryRolesByParamsSql(@Param("roleName") final String roleName){ return new SQL(){ { SELECT("id,role_name as roleName,role_remark as roleRemark," + "create_date as createDate,update_date as updateDate," + " is_valid as isValid"); FROM("t_role"); WHERE("is_valid=1"); if(StringUtils.isNoneBlank(roleName)){ WHERE("role_name like concat('%',#{roleName},'%')"); } } }.toString(); } }
RoleMapper.xml
<select id="queryRolesByParams" resultType="role"> select <include refid="role_column" /> from t_role <where> is_valid = 1 <if test="roleName !=null and roleName !=''"> and role_name like concat('%',#{roleName},'%') </if> </where> </select>
注:
@SelectProvider 和 PageHelper 一起使用可能報(bào)錯(cuò)
報(bào)錯(cuò)是這樣的
There is no getter for property named 'providerTakesParameterObject'
問(wèn)題描述:
使用@SelectProvider注解,進(jìn)行查詢的時(shí)候報(bào)錯(cuò)
下面也是是這個(gè)問(wèn)題引起的,重啟Eclipse可能出現(xiàn)這個(gè)提示
Source not found for org.mortbay.io.nio.SelectChannelEndPoint
解決原因:
項(xiàng)目中使用了PageHelper 進(jìn)行分頁(yè),與@@SelectProvider這個(gè)注解不能一起使用
不使用 PageHelper 這個(gè)插件,sql是正常運(yùn)行的
解決方式:改用 xml 進(jìn)行sql 查詢
同樣問(wèn)題,其他解決方式參考:
https://stackoverflow.com/questions/37744893/how-can-sqlprovider-take-more-than-1-param-in-mybatis
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot的@GetMapping路徑匹配規(guī)則、國(guó)際化詳細(xì)教程
這篇文章主要介紹了SpringBoot的@GetMapping路徑匹配規(guī)則、國(guó)際化,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-11-11SpringBoot 動(dòng)態(tài)配置Profile環(huán)境的方式
這篇文章主要介紹了SpringBoot 動(dòng)態(tài)配置Profile環(huán)境的方式,本文通過(guò)圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-10-10java如何用Processing生成馬賽克風(fēng)格的圖像
這篇文章主要介紹了如何用java如何用Processing生成馬賽克風(fēng)格的圖像,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03java學(xué)習(xí)之jar包的下載和導(dǎo)入
我們經(jīng)常碰到有些jar包在中央倉(cāng)庫(kù)沒(méi)有的情況,這時(shí)候我們需要導(dǎo)入,這篇文章主要給大家介紹了關(guān)于java學(xué)習(xí)之jar包的下載和導(dǎo)入的相關(guān)資料,需要的朋友可以參考下2023-06-06IDEA運(yùn)行SpringBoot項(xiàng)目的詳細(xì)步驟(圖文教程)
本文主要介紹了IDEA運(yùn)行SpringBoot項(xiàng)目的詳細(xì)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07java保證一個(gè)方法只能執(zhí)行一次的問(wèn)題
這篇文章主要介紹了java保證一個(gè)方法只能執(zhí)行一次的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08關(guān)于Java中String類(lèi)字符串的解析
這篇文章主要介紹有關(guān)Java中String類(lèi)字符串的解析,在java中,和C語(yǔ)言一樣,也有關(guān)于字符串的定義,并且有他自己特有的功能,下面就進(jìn)入主題一起學(xué)習(xí)下面文章內(nèi)容吧2021-10-10Java Swing JTextArea文本區(qū)域的實(shí)現(xiàn)示例
這篇文章主要介紹了Java Swing JTextArea文本區(qū)域的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12springboot常用語(yǔ)法庫(kù)的基本語(yǔ)法
FreeMarker 是一款?模板引擎: 即一種基于模板和要改變的數(shù)據(jù), 并用來(lái)生成輸出文本(HTML網(wǎng)頁(yè),電子郵件,配置文件,源代碼等)的通用工具,這篇文章主要介紹了springboot常用語(yǔ)法庫(kù)的基本語(yǔ)法,需要的朋友可以參考下2022-12-12