JAVA框架 Mybaits 动态sql
动态sql
一:if标签使用:
我们在查询的时候,有时候由于查询的条件的不确定性,导致where的后面的条件的不同,这时候就需要我们进行where后面的条件进行拼接。
Mapper配置文件:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="jd.com.vodemo.voMapper" >
<select id="findAccByIdAndName" resultType="jd.com.mybaitstest.account" parameterType="jd.com.vodemo.vodemo">
SELECT * FROM t_account WHERE = AND
<if test="ac.name!=null and ac.name!=''">
NAME LIKE '%${ac.name}%'
</if>
<if test="ac.id!=null and ac.id!=''">
AND id >#{ac.id}
</if>
</select>
</mapper>
注意:我们需要使用SELECT * FROM t_account WHERE 1=1 AND 条件1 AND 条件2.。。。。。这种使用。
其中if标签中的test表达式是测试条件和字段是否为空或者nul,注意这里也是属性.属性。
实际的输出语句:
2018-04-25 18:40:14,733 DEBUG [main] voMapper.findAccByIdAndName.debug:139 | ==> Preparing: SELECT * FROM t_account WHERE 1=1 AND NAME LIKE '%ok%' AND id >?
二、where标签:可以帮我们补全where关键字也不需要1=1的条件:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="jd.com.vodemo.voMapper" >
<select id="findAccByIdAndName" resultType="jd.com.mybaitstest.account" parameterType="jd.com.vodemo.vodemo">
SELECT * FROM t_account
<where>
<if test="ac.name!=null and ac.name!=''">
NAME LIKE '%${ac.name}%'
</if>
<if test="ac.id!=null and ac.id!=''">
And id >#{ac.id}
</if>
</where> </select>
</mapper>
sql语句:

如果别的查询语句也需要这些条件 我们可以进行重用。
在<mapper>标签下面 使用sql标签。
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="jd.com.vodemo.voMapper" >
6 <sql id="useMangCon" >
7 <where>
8 <if test="ac.name!=null and ac.name!=''">
9 NAME LIKE '%${ac.name}%'
10 </if>
11 <if test="ac.id!=null and ac.id!=''">
12 And id >#{ac.id}
13 </if>
14 </where>
15 </sql>
<select id="findAccByIdAndName" resultType="jd.com.mybaitstest.account" parameterType="jd.com.vodemo.vodemo" > SELECT * FROM t_account
<include refid="useMangCon" /> </select>
</mapper>
其种id是唯一是别人调用的时候标识。
相应的引用使用的标签是include标签。
<include refid="useMangCon" />
这样这部分的条件可以进行复用。
三、foreach的标签
当前端传来一些列的id,为列表的时候,我们可以使用id进行查询。这时候sql使用的是in而 不是or or的效率很低。
<foreach collection="ids" item="xx" open="where id IN (" close=")" separator="," >
#{xx}
</foreach>
首先了解下foreach的里的属性意思:
1、collection:集合,就是传入的变量的集合的名称。这个需要跟你传入的对象内的属性字段相对应!
2、item:循环的元素,将元素放入这个item中(是将ids的元素放在item里面不是一个而是整个集合)。
3、open:循环开始的拼接符。
4、colse:循环结束的拼接符。
5、separator:就是sql语句中集合内的元素之间的分隔符。
6、#{xx}:取出item的集合。这个名字要和item的名字一样。因为是同一个变量的名称。
完整的例子:
<select id="findAccByIdList" parameterType="jd.com.vodemo.vodemo" resultType="jd.com.mybaitstest.account" >
SELECT * FROM t_account
<!--<where>-->
<foreach collection="ids" item="xx" open="where id IN (" close=")" separator="," >
#{xx}
</foreach>
<!--</where>--> </select>
其中的where标签可以有也可以没有,只是在foreach中的open拼接的时候需要注意带不带where就可以。
其中parameterType不能写:List<Integer> 会报:columnNumber: 53; 与元素类型 "select" 相关联的 "parameterType" 属性值不能包含 '<' 字符 所以传入对象。
vo类:
package jd.com.vodemo;
import jd.com.mybaitstest.account; import java.util.List; public class vodemo {
private List<Integer> ids; private account ac; public void setAc(account ac) {
this.ac = ac;
} public account getAc() {
return ac;
} public void setIds(List<Integer> ids) {
this.ids = ids;
} public List<Integer> getIds() {
return ids;
}
}
接口:
package jd.com.vodemo;
import jd.com.mybaitstest.account;
import java.util.List; public interface voMapper { List<account> findAccByIdAndName(vodemo vo);
List<account> findAccByIdList(vodemo vo);
}
mapper类:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="jd.com.vodemo.voMapper" >
<sql id="useMangCon" >
<where>
<if test="ac.name!=null and ac.name!=''">
NAME LIKE '%${ac.name}%'
</if>
<if test="ac.id!=null and ac.id!=''">
And id >#{ac.id}
</if>
</where>
</sql>
<select id="findAccByIdAndName" resultType="jd.com.mybaitstest.account" parameterType="jd.com.vodemo.vodemo" > SELECT * FROM t_account
<include refid="useMangCon" /> </select>
<select id="findAccByIdList" parameterType="List<Integer>" resultType="jd.com.mybaitstest.account" >
SELECT * FROM t_account
<!--<where>-->
<foreach collection="ids" item="xx" open="where id IN (" close=")" separator="," >
#{xx}
</foreach>
<!--</where>--> </select>
</mapper>
JAVA框架 Mybaits 动态sql的更多相关文章
- JAVA框架 Mybaits 动态代理
一.动态代理: mybaits给咱们提供一套动态代理,我们只需要按他的要求写接口即可,mybatis帮做动态代理,相当于咱们写的接口的实现类.底层通过反射实例化代理对象,通过代理对象调用相应的方法, ...
- mybatis框架(5)---动态sql
那么,问题来了: 什么是动态SQL? 动态SQL有什么作用? 传统的使用JDBC的方法,相信大家在组合复杂的的SQL语句的时候,需要去拼接,稍不注意哪怕少了个空格,都会导致错误.Mybatis的动态S ...
- mybatis框架中动态SQL的编写
1.动态SQL:在SQL语句中加入流程控制.比如加入if,foreach等. 重点掌握if语句: 案例1: <update id="updateItem" parameter ...
- Mybaits动态Sql
什么是动态SQL? MyBatis的强大之处便是它的动态SQL,如果你使用JDBC那么在根据不同条件查询时,拼接SQL语句是多么的痛苦. 比如查询一个学生信息,可以根据学生的姓名,性别,班级,年龄,学 ...
- JAVA框架 Mybaits
注意:我们在resultType中,对于selectlist方法也是projo类.resultType参数的含义是list的泛型的类型. 一:jar包下载: https://github.com/m ...
- java EE实现动态SQL的
结果图 情况一:
- JAVA框架 Mybaits 一对一、一对多
一:阐述 我们在日常操作的时候,很多时候会遇到多表联合查询,由于参照物的不通 ,会出现一对一.一对多的情况.比如说:账号信息和订单表,从订单表角度和账号信息是一对一的情况(一个订单只能是一个用户的情况 ...
- JAVA框架 Mybaits 输入和输出映射
一.输入映射 当前端传来的参数,比较复杂,比如说用户名称.订单单号.账号信息等等.后端有可能有多个projo类对应这些信息.我们需要把这些的projo类封装成一个类似一个vo类. 通过设置字段形式关联 ...
- JAVA框架 Mybaits 核心配置
一:mybaits的核心配置文件:SqlMapConfig.xml 配置文件中需要关注的属性: 二.properites属性:一般引用配置文件(properites文件)比如:数据库的配置.我们可以编 ...
随机推荐
- 解决 iframe 后退不是主页面后退(浏览器 history)问题
前言:项目中的主页面里有 iframe,切换 iframe 的 src 地址之后,再点浏览器的回退之后,会导致 iframe 里面回退,而不是主页面回退. 问题 浏览器机制的原因,在 iframe 导 ...
- php+redis实战留言板(todolist)与互粉功能
目的:通过留言板(todolist)与互粉功能,掌握php操作redis的方法 相关数据操作命令 1,keys * 查看数据库所有的key 2,type + key: 如 type uid 查 ...
- AngularJS table 按照表头字段排序功能(升序和降序)
一.表格按照表头排序 <!doctype html> <html ng-app="a3_4"> <head> <title>表头排序 ...
- Vue 爬坑之路(十)—— Vue2.5 + Typescript 构建项目
Typescript 在前端圈已经逐渐普及,Vue 2.5.0 改进了类型声明,使得对 TypeScript 更加友好 不过要想在项目中直接使用 TypeScript 仍然需要对项目进行一些改造 P ...
- javax.net.ssl.SSLHandshakeException sun.security.validator.ValidatorException PK
javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building f ...
- 【代码笔记】iOS-NSSearchPathForDirectoriesInDomainsDemo
一,代码. - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, ...
- 树莓派 引脚及接口图 AV接口顺序
树莓派 引脚图 注:本表格适用于各版本,并且兼容26Pin的树莓派B,树莓派B为26Pin,其引脚对应于上表的前26Pin. 树莓派 接口图 AV接口又称(RCA),AV接口算是出现比较早的一种接 ...
- 关于动态加载js
已知一个需要动态加载的js的文件路径数组,动态加载数组里面所有的js文件. 加载分两种情况: 1. 并行加载,不管js的执行顺序. 2. 串行加载,即一个一个加载,上一个加载完再加载下一个,直到最后. ...
- ubuntu下编译qt5
编译步骤参考: http://doc.qt.io/qt-5/linux.html 我们使用源代码和编译目录分离的编译方式, 这样避免编译主机系统和目标系统间的独立. 参考: Qt Configure ...
- 互联网,IT,大数据,机器学习,AI知识tag云
互联网基础: tcp/ip网络,linux运维,DNS,ipv6 web前端: javascript, es6, 组件化开发, vuejs, angularjs, react html5, css3, ...