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è)參考,也希望大家多多支持服務(wù)器之家。
原文鏈接:https://icecoola.blog.csdn.net/article/details/78079281