浅谈sql_@SelectProvider及使用注意说明


Posted in Java/Android onAugust 04, 2021

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注解,进行查询的时候报错

浅谈sql_@SelectProvider及使用注意说明

下面也是是这个问题引起的,重启Eclipse可能出现这个提示

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

浅谈sql_@SelectProvider及使用注意说明

解决原因:

项目中使用了PageHelper 进行分页,与@@SelectProvider这个注解不能一起使用

浅谈sql_@SelectProvider及使用注意说明

不使用 PageHelper 这个插件,sql是正常运行的

浅谈sql_@SelectProvider及使用注意说明

解决方式:改用 xml 进行sql 查询

同样问题,其他解决方式参考:

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Java/Android 相关文章推荐
Java实现二维数组和稀疏数组之间的转换
Jun 27 Java/Android
Java中多线程下载图片并压缩能提高效率吗
Jul 01 Java/Android
新手初学Java网络编程
Jul 07 Java/Android
gateway与spring-boot-starter-web冲突问题的解决
Jul 16 Java/Android
Java spring定时任务详解
Oct 05 Java/Android
Java 在线考试云平台的实现
Nov 23 Java/Android
SpringDataJPA在Entity中常用的注解介绍
Dec 06 Java/Android
Spring Bean是如何初始化的详解
Mar 22 Java/Android
MybatisPlus EntityWrapper如何自定义SQL
Mar 22 Java/Android
Dubbo+zookeeper搭配分布式服务的过程详解
Apr 03 Java/Android
SpringBoot中获取profile的方法详解
Apr 08 Java/Android
SpringCloud Function SpEL注入漏洞分析及环境搭建
Apr 08 Java/Android
mybatis3中@SelectProvider传递参数方式
Aug 04 #Java/Android
浅谈Java父子类加载顺序
Aug 04 #Java/Android
浅谈spring boot使用thymeleaf版本的问题
Aug 04 #Java/Android
Java后台生成图片的完整步骤
Aug 04 #Java/Android
在Spring-Boot中如何使用@Value注解注入集合类
Aug 02 #Java/Android
SpringBoot整合RabbitMQ的5种模式实战
Log4j.properties配置及其使用
Aug 02 #Java/Android
You might like
PHP 5.0对象模型深度探索之绑定
2006/09/05 PHP
PHP程序61条面向对象分析设计的经验小结
2008/11/12 PHP
解析PHP中intval()等int转换时的意外异常情况
2013/06/21 PHP
Smarty模板变量调节器用法分析
2016/05/23 PHP
php实现表单提交上传文件功能
2018/05/28 PHP
PHP实现二维数组中的查找算法小结
2018/06/09 PHP
php使用curl模拟多线程实现批处理功能示例
2019/07/25 PHP
dojo 之基础篇(三)之向服务器发送数据
2007/03/24 Javascript
使用SyntaxHighlighter实现HTML高亮显示代码的方法
2010/02/04 Javascript
javascript垃圾收集机制与内存泄漏详细解析
2013/11/11 Javascript
jquery获取当前点击对象的value方法
2014/02/28 Javascript
jsPDF导出pdf示例
2014/05/02 Javascript
Python脚本后台运行的几种方式
2015/03/09 Javascript
jQuery与JavaScript节点创建方法的对比
2016/11/18 Javascript
Boostrap栅格系统与自己额外定义的媒体查询的冲突问题
2017/02/19 Javascript
深入理解Vue 的条件渲染和列表渲染
2017/09/01 Javascript
浅谈Vue内置component组件的应用场景
2018/03/27 Javascript
微信小程序实现左右列表联动
2020/05/19 Javascript
详解关于React-Router4.0跳转不置顶解决方案
2019/05/10 Javascript
JS实现TITLE悬停长久显示效果完整示例
2020/02/11 Javascript
[37:02]OG vs INfamous 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
使用python编写批量卸载手机中安装的android应用脚本
2014/07/21 Python
Python随手笔记之标准类型内建函数
2015/12/02 Python
Python读取txt文件数据的方法(用于接口自动化参数化数据)
2018/06/27 Python
详解python中@的用法
2019/03/27 Python
PyQtGraph在pyqt中的应用及安装过程
2019/08/04 Python
安装2019Pycharm最新版本的教程详解
2019/10/22 Python
介绍一下JNDI的基本概念
2013/07/26 面试题
Servlet方面面试题
2016/09/28 面试题
2013年办公室秘书的个人自我鉴定
2013/10/24 职场文书
土地转让协议书
2014/04/15 职场文书
伊索寓言教学反思
2014/05/01 职场文书
超市仓管员岗位职责范本
2014/09/18 职场文书
2015年幼儿园学前班工作总结
2015/05/18 职场文书
2019升学宴主持词范本5篇
2019/10/09 职场文书
Android超详细讲解组件ScrollView的使用
2022/03/31 Java/Android