淺談sql_@SelectProvider及使用註意說明

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 一起使用可能報錯

報錯是這樣的

There is no getter for property named ‘providerTakesParameterObject’

問題描述:

使用@SelectProvider註解,進行查詢的時候報錯

下面也是是這個問題引起的,重啟Eclipse可能出現這個提示

Source not found for org.mortbay.io.nio.SelectChannelEndPoint

解決原因:

項目中使用瞭PageHelper 進行分頁,與@@SelectProvider這個註解不能一起使用

不使用 PageHelper 這個插件,sql是正常運行的

解決方式:改用 xml 進行sql 查詢

同樣問題,其他解決方式參考:

https://stackoverflow.com/questions/37744893/how-can-sqlprovider-take-more-than-1-param-in-mybatis

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。

推薦閱讀: