MyBatis在注解中使用动态查询

以前为了使用注解并在注解中融入动态查询,会使用Provider。后来发现只要加入"<script>包含动态查询的SQL语句</script>"就可以了。

例如:

sql 复制代码
    @Select("<script>" +
            "select  v.*,u.avatar,u.nickname from videos v join users u on v.uid = u.id " +
            "<where>" +
            "<if test= \'keyword!=null and keyword!=\"\" \' >" +
            " v.video_desc like '%${keyword}%'" +
            "</if> " +
            "and v.status = 1 " +
            "</where>" +
            "order by v.create_time desc"+
            "</script>")
    public List<UserVideosResp> getAllVideosByKeyword(String keyword);

需要提示两点的是:

  1. SQL语句是使用字符串的拼接形成的,要特别注意组成SQL语句的字符串后面是不是有足够的空格。字符串拼接出来的SQL是不是符合SQL应有的语法格式。
  2. <if test='...'> if标签写在test属性中的判定条件必须用引号包裹,否则会产生错误。
相关推荐
吕了了11 分钟前
给U盘一个PE to Go:将微PE系统直接释放到U盘
运维·windows·电脑·系统
总有刁民想爱朕ha1 小时前
MySQL 8 Windows日常维护教程(安装、备份、还原、重置密码等)
windows·mysql
世转神风-2 小时前
ps1脚本-运行报错-并带有乱码
windows·脚本
青w韵2 小时前
Claude 高级工具使用解析:从上下文优化到程序化调用的工程实践
数据库·windows
淼淼7632 小时前
Qt拖动工具栏控件到图页中均匀展示
开发语言·c++·windows·qt
武藤一雄3 小时前
[.NET] 中 System.Collections.Generic命名空间详解
windows·微软·c#·asp.net·.net·.netcore
CPU不够了4 小时前
winsw实现windows服务
windows
TheNextByte14 小时前
适用于Windows和Mac电脑的Android文件传输工具
windows·macos·电脑
石像鬼₧魂石4 小时前
Fail2Ban 一键部署 + 管理脚本(可直接执行)
linux·windows·学习·ubuntu
石像鬼₧魂石4 小时前
Fail2Ban 实战终极速查表
linux·windows·学习·ubuntu