05.Mybatis动态sql
1.IF标签
需求:根据条件查询用户
在Mapper.xml中编写
<!-- 根据sex和username查询user --> <select id="findbySexandUsername" parameterType="User" resultType="User"> select * from user where sex = #{sex} and username = #{username} </select>
问题:当传入的参数中缺少需要的属性时,不能查出信息
使用IF标签解决:
<!-- 根据sex和username查询user --> <select id="findbySexandUsername" parameterType="User" resultType="User"> select * from user where 1=1 <if test="sex!=null and sex!='' "> and sex = #{sex} </if> <if test="username!=null and username!='' "> and username = #{username} </if> </select>
2.WHERE标签
问题:上面的IF标签 中 Where 1=1 显得很麻烦
使用where解决
<!-- 根据sex和username查询user --> <select id="findbySexandUsername" parameterType="User" resultType="User"> select * from user <!-- where标签可以自动添加where,同时处理sql语句中第一个and关键字 --> <where> <if test="sex!=null and sex!='' "> and sex = #{sex} </if> <if test="username!=null and username!='' "> and username = #{username} </if> </where> </select>
where标签可以自动添加where,同时处理sql语句中第一个and关键字
3.SQL标签
问题:在一个Mapper.xml中有许多重复的语句
使用SQL标签解决
<!-- 查询所有的orders --> <select id="findAllOrders" resultMap="ordersResultMap"> select * from orders </select> <!-- 声明sql片段 --> <sql id="selectUser"> select * from user </sql> <!-- 根据sex和username查询user --> <select id="findbySexandUsername" parameterType="User" resultType="User"> <include refid="selectUser"/> <!-- where标签可以自动添加where,同时处理sql语句中第一个and关键字 --> <where> <if test="sex!=null and sex!='' "> and sex = #{sex} </if> <if test="username!=null and username!='' "> and username = #{username} </if> </where> </select>
如果要使用别的namespace中的sql标签,在refid中加入namespace名字
4.FOREACH
当查询需要用到in时。例如:根据多个id查询用户信息
需要通道foreach标签
1.数组
接口
/** * 根据ids来查询 */ public List<User> findByIds(int[] ids);
映射
<!-- 根据ids来查询 --> <select id="findByIds" parameterType="int[]" resultType="User"> select * from user where id in <!-- foreach标签,进行遍历 --> <!-- collection:遍历的集合 --> <!-- item:遍历的项目,可以随便写,,但是和后面的#{}里面要一致 --> <!-- open:在前面添加的sql片段 --> <!-- close:在结尾处添加的sql片段 --> <!-- separator:指定遍历的元素之间使用的分隔符 --> <foreach collection="ids" item="id" open="(" close=")" separator=","> #{id} </foreach> </select>
测试
/** * 根据ids */ @Test public void m05() { // 获取sqlSession,和Spring整理后由Spring管理 SqlSession sqlSession = this.sqlSessionFactory.openSession(); // 从sqlSession中获取Mapper接口的代理对象 UserMapper userMapper = sqlSession.getMapper(UserMapper.class); // 执行查询 int[] ids = new int[3]; ids[0] = 10; ids[1] = 16; ids[2] = 22; List<User> list = userMapper.findByIds(ids); for (User user : list) { System.out.println(user); } }
注意:这样写会报错
原因:这种情况映射中的collection必须按照规范写
ids 改为 array
再次测试:
2.集合
/** * 根据ids */ @Test public void m05() { // 获取sqlSession,和Spring整理后由Spring管理 SqlSession sqlSession = this.sqlSessionFactory.openSession(); // 从sqlSession中获取Mapper接口的代理对象 UserMapper userMapper = sqlSession.getMapper(UserMapper.class); // 执行查询 List<Integer> ids = new ArrayList<>(); ids.add(10); ids.add(16); ids.add(22); List<User> users = userMapper.findByIds(ids); for (User user : users) { System.out.println(user); } } }
/** * 根据ids来查询 */ public List<User> findByIds(List ids);
<!-- 根据ids来查询 --> <select id="findByIds" parameterType="List" resultType="User"> select * from user where id in <!-- foreach标签,进行遍历 --> <!-- collection:遍历的集合,这里是QueryVo的ids属性 --> <!-- item:遍历的项目,可以随便写,,但是和后面的#{}里面要一致 --> <!-- open:在前面添加的sql片段 --> <!-- close:在结尾处添加的sql片段 --> <!-- separator:指定遍历的元素之间使用的分隔符 --> <foreach collection="ids" item="id" open="(" close=")" separator=","> #{id} </foreach> </select>
注意:同样不能随意写collection
应该将 ids 改为 list
05.Mybatis动态sql的更多相关文章
- MyBatis 动态SQL(十二)
动态条件查询 以下是我们数据库表 tb_user 的记录: 假设现在有一个需求,就是根据输入的用户年龄和性别,查询用户的记录信息.你可能会说,这太简单了,脑袋里立马蹦出如下的 SQL 语句: SELE ...
- mybatis动态sql以及分页
1.mybatis动态sql 2.模糊查询 3.查询返回结果集的处理 4.分页查询 5.特殊字符处理 1.mybatis动态sql If.trim.foreach If 标签判断某一字段是否为空 &l ...
- mybatis实战教程(mybatis in action)之八:mybatis 动态sql语句
mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类:1. if 语句 (简单的条件判断)2. c ...
- 9.mybatis动态SQL标签的用法
mybatis动态SQL标签的用法 动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么 ...
- 自己动手实现mybatis动态sql
发现要坚持写博客真的是一件很困难的事情,各种原因都会导致顾不上博客.本来打算写自己动手实现orm,看看时间,还是先实现一个动态sql,下次有时间再补上orm完整的实现吧. 用过mybatis的人,估计 ...
- Mybatis动态SQL单一基础类型参数用if标签
Mybatis动态SQL单一基础类型参数用if标签时,test中应该用 _parameter,如: 1 2 3 4 5 6 <select id="selectByName" ...
- 超全MyBatis动态SQL详解!( 看完SQL爽多了)
MyBatis 令人喜欢的一大特性就是动态 SQL. 在使用 JDBC 的过程中, 根据条件进行 SQL 的拼接是很麻烦且很容易出错的. MyBatis 动态 SQL 的出现, 解决了这个麻烦. My ...
- Mybatis动态SQL简单了解 Mybatis简介(四)
动态SQL概况 MyBatis 的强大特性之一便是它的动态 SQL 在Java开发中经常遇到条件判断,比如: if(x>0){ //执行一些逻辑........ } Mybatis应用中,S ...
- mybatis原理分析学习记录,mybatis动态sql学习记录
以下个人学习笔记,仅供参考,欢迎指正. MyBatis 是支持定制化 SQL.存储过程以及高级映射的持久层框架,其主要就完成2件事情: 封装JDBC操作 利用反射打通Java类与SQL语句之间的相互转 ...
随机推荐
- [JZOJ 5817] 抄代码
题意: 给定2T个串,带修的判断两个串是否按规则一样?? 思路: 两个串是"抄袭的"肯定就是: 1.长度一样. 2.特殊字符位置一样 3.对于每个\(x\)在两个串中出现位置一样, ...
- GoF著作中未提到的设计模式(2):Interceptor
转:http://www.cnblogs.com/west-link/archive/2011/06/22/2086591.html 拦截器模式为我们提供了一种拦截方法调用或消息的途径,整个过程是自动 ...
- AtCoder ABC 128E Roadwork
题目链接:https://atcoder.jp/contests/abc128/tasks/abc128_e 题目大意 在一条路上(这条路可以看做坐标轴 x 轴从 0 开始方向为正无穷方向的射线),有 ...
- CodeForces 1152F1 Neko Rules the Catniverse (Small Version)
题目链接:http://codeforces.com/problemset/problem/1152/F1 题目大意 有 n 个星球,给定限制 m,从 x 星球走到 y 星球的条件是,$1 \leq ...
- Codeforces 1174B Ehab Is an Odd Person
题目链接:http://codeforces.com/problemset/problem/1174/B 题意:给定长度 n 的数组,任意俩个相加为奇数的数可以交换数组中的位置,让这个数组尽量从小到大 ...
- 过滤'and','or' ''' '*' '=' ‘select’下的注入
遇到一个站:http://www.马赛克.net/intro.aspx?id=6 加了单引号 http://www.马赛克.net/intro.aspx?id=6‘ 页面无变化 加了双引号 h ...
- 剑指offer——24链表中倒数第k个结点
题目描述 输入一个链表,输出该链表中倒数第k个结点. 题解: 1.普通解法,先遍历一遍计算链表长度,然后遍历到倒数第k个节点: 2.只遍历一遍,使用双指针,使得头尾指针位差为k,那么当尾指针为空时 ...
- 《转》python 10 集合
自 http://www.cnblogs.com/BeginMan/p/3160565.html 一.目录 1.集合概述 2.关于集合的操作符.关系符号 3.集合的一系列操作(添加.更新.访问.删除) ...
- 9款很棒的网页绘制图表JavaScript框架脚本
推荐9款很棒的可在网页中绘制图表的JavaScript脚本,这些有趣的JS脚本可以帮助你快速方便的绘制图表(线.面.饼.条…),其中包括jQuery.MooTools.Prototype和一些其它的J ...
- YARN设计思路