栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

12-MyBatis 动态SQL

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

12-MyBatis 动态SQL

1.相关知识

动态 SQL,通过 MyBatis 提供的各种标签对条件作出判断以实现动态拼接 SQL 语句。这里的条件判断使用的表达式为 OGNL 表达式。常用的动态 SQL 标签有< if >、< where >、< choose >、< foreach >等。MyBatis 的动态 SQL 语句,与 JSTL 中的语句非常相似。

动态 SQL,主要用于解决查询条件不确定的情况:在程序运行期间,根据用户提交的查询条件进行查询。提交的查询条件不同,执行的 SQL 语句不同。若将每种可能的情况均逐一列出,对所有条件进行排列组合,将会出现大量的 SQL 语句。此时,可使用动态 SQL 来解决这样的问题

注意: 在 mapper 的动态 SQL 中若出现大于号(>)、小于号(<)、大于等于号(>=),小于等于号(<=)等符号,最好将其转换为实体符号。否则,XML 可能会出现解析出错问题。特别是对于小于号(<),在 XML 中是绝不能出现的, 否则解析 mapper 文件会出错。

实体符号表:

2.< if >标签

对于该标签的执行,当 test 的值为 true 时,会将其包含的 SQL 片断拼接到其所在的 SQL 语句中。
语法:< if test=”条件” > sql 语句的部分

xml

    
        select * from t_user
        
            order by ${column} desc
        
    

dao

    //获取所有学生记录, column排序的参数
    List getAllUser(@Param("column") String column);

测试
a.不传入排序参数

 	List userList = userDao.getAllUser(null);
 	userList.forEach(user -> System.out.println(user));


b.传入排序参数user_name

    List userList = userDao.getAllUser("user_name");
    userList.forEach(user -> System.out.println(user));

3.< where >标签

< if >标签的中存在一个比较麻烦的地方:若 where 后的所有< if>条件均为 false,而 where 后若又没有 1=1 子句,则 SQL 中就会只剩下一个空的 where,SQL出错。

    
        select * from t_user where id!=-1
        
            and user_name = #{name}
        
    

但当数据量很大时,会严重影响查询效率。

使用< where >标签,在有查询条件时,可以自动添加上 where 子句;没有查询条件时,不会添加
where 子句。需要注意的是,第一个标签中的 SQL 片断,可以不包含 and。不过,写上 and 也不错,系统会将多出的 and 去掉。但其它中 SQL 片断的 and,必须要求写上。否则 SQL 语句将拼接出错.
xml

    
        select * from t_user
        
            where id in
            
                #{myId}
            
        
    

dao

	List getUserByIdList(List myList);

测试

  	List list = new linkedList<>();
  	list.add(2);
  	list.add(3);
  	list.add(4);
  	List userList = userDao.getUserByIdList(list);
  	userList.forEach(user -> System.out.println(user));


(2) 遍历 List<对象类型>

    
        
        
        where id = #{id}
    

dao

	User getUserById(Integer id);

测试

    User user = userDao.getUserById(2);
    System.out.println(user);


关于动态SQL的标签还有很多, 详细情况请见官网文档
https://mybatis.org/mybatis-3/zh/dynamic-sql.html

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/708731.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号