Mpper.xml映射文件中定义了操作数据库的sql,并且提供了各种标签方法实现动态拼接sql。每个sql是一个statement,映射文件是mybatis的核心。

一、内容标签

1、NamePlace

NamePlace命名空间作用就是对sql进行分类化管理。若使用Dao开发方式,映射文件的nameplace可以任意命名;但如果采用的是Mapper接口代理的方式开发,Mapper的映射文件中namespace必须为接口的全名。

<?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="Mapper.EmpMapper">//CURD操作标签
        //if片段
</mapper>

2、CRUD标签

<?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="Mapper.EmpMapper"><!-- 查询 --><select id="" parameterType="" resultType=""></select><!-- 添加 --><insert id="" parameterType=""></insert><!-- 删除 --><delete id="" parameterType=""></delete><!-- 更新 --><update id="" parameterType=""></update>
</mapper>

3、标签调用方法

(1)selectOne与selectList方法

selectOne表示查询出一条结果集进行映射,使用selectOne查询多条记录会抛出异常。selectList表示查询出一个列表(多条记录)进行映射,对于使用selectOne可以实现的查询,使用selectList必然也可以实现(list中只有一个对象)。

(3)代理对象内部调用

动态代理对象调用sqlSession.selectOne()和sqlSession.selectList()是根据mapper接口方法的返回值决定,如果mapper方法返回单个pojo对象(非集合对象),代理对象内部通过selectOne查询数据库。如果mapper方法返回集合对象,代理对象内部通过selectList查询数据库。

二、动态SQL标签

1、if标签

//进行空字符串校验
<select id="findUserList" parameterType="user" resultType="user">select * from user  where 1=1<if test="id!=null and id!=''">and id=#{id}</if><if test="username!=null and username!=''">and username like '%${username}%'</if>
</select>

2、where标签

//<where/>可以自动处理第一个and
<select id="findUserList" parameterType="user" resultType="user">select * from user<where><if test="id!=null and id!=''">and id=#{id}</if><if test="username!=null and username!=''">and username like '%${username}%'</if></where>
</select>

3、sql片段

Sql中可将重复的sql提取出来,使用时用include引用即可,最终达到sql重用的目的,如下:

//建立sql片段
<sql id="query_user_where"><if test="id!=null and id!=''">and id=#{id}</if><if test="username!=null and username!=''">and username like '%${username}%'</if>
</sql>//使用include引用sql片段
<select id="findUserList" parameterType="user" resultType="user">select * from user<where><include refid="query_user_where"/></where>
</select>//引用其它mapper.xml的sql片段
<include refid="namespace.sql片段"/>

三、foreach标签

1、通过pojo类传递list

向sql传递数组或List,mybatis使用foreach解析,foreach参数定义如下:collection指定输入 对象中集合属性,  item每个遍历生成对象中,open开始遍历时拼接的串,close结束遍历时拼接的串,separator:遍历的两个对象中需要拼接的串。

(1)sql语句

SELECT * FROM USERS WHERE username LIKE '%张%' AND (id =10 OR id =89 OR id=16)
SELECT * FROM USERS WHERE username LIKE '%张%' id IN (10,89,16)

(2)vo类

public class QueryVo{private User user;
        private UserCustom userCustom;//传递多个用户idprivate List<Integer> ids;set()/get()  ...
}

(3)映射文件

<select id="findUserList" parameterType="UserQueryVo" resultType="UserCustom">
     SELECT * FROM USER
     <where>
        <!-- 使用实现下边的sql拼接: AND (id=1 OR id=10 OR id=16) -->

<if test="ids!=null and ids.size>0">

<foreach collection="ids" item="user_id" open="AND (" close=")" separator="or">

id=#{user_id}

</foreach>

</if>
     </where>
</select>

<!-- 使用实现下边的sql拼接: and id IN(1,10,16)—>

<foreach collection="ids" item="user_id" open="and id IN(" close=")" separator=",">

#{user_id}

</foreach>

(4)测试代码

List<Integer> ids = new ArrayList<Integer>();
ids.add(1);//查询id为1的用户
ids.add(10); //查询id为10的用户
queryVo.setIds(ids);
List<User> list = userMapper.findUserList(queryVo);

2、传递单个list

(1)Mapper映射文件

<select id="selectUserByList" parameterType="java.util.List" resultType="user">select * from user<where><!-- 传递List,List中是pojo --><if test="list!=null"><foreach collection="list" item="item" open="and id in( "separator="," close=")">#{item.id}</foreach></if></where>
</select>

(2)Mapper接口

public List<User> selectUserByList(List userlist);

(3)测试程序

//构造查询条件List
List<User> userlist = new ArrayList<User>();
User user = new User();
user.setId(1);
userlist.add(user);user = new User();
user.setId(2);
userlist.add(user);
//传递userlist列表查询用户列表
List<User>list = userMapper.selectUserByList(userlist);

3、传递pojo类数组

(1)Mapper映射文件

参数含义:index为数组的下标,item为数组每个元素的名称,名称随意定义,open循环开始,close循环结束,separator中间分隔输出。

<select id="selectUserByArray" parameterType="Object[]" resultType="user">select * from user<where><!-- 传递pojo类数组 --><if test="array!=null"><foreach collection="array" index="index" item="item"open="and id in("separator=","close=")">#{item.id}</foreach></if></where>
</select>

(2)Mapper接口

public List<User> selectUserByArray(Object[] userlist)

(3)测试程序

//构造查询条件List
Object[] userlist = new Object[2];
User user = new User();
user.setId(1);
userlist[0]=user;user = new User();
user.setId(2);
userlist[1]=user;//传递user对象查询用户列表
List<User>list = userMapper.selectUserByArray(userlist);

4、传递字符串类数组

(1)Mapper映射文件

<select id="selectUserByArray" parameterType="Object[]" resultType="user">select * from user<where><!-- 传递字符串数组 --><if test="array!=null"><foreach collection="array"index="index"item="item"open="and id in("separator=","close=")"> #{item}</foreach></if></where>
</select>

如果数组中是简单类型则写为#{item},不用再通过ognl获取对象属性值了。

(2)Mapper接口

public List<User> selectUserByArray(Object[] userlist)

(3)测试程序

//构造查询条件List
Object[] userlist = new Object[2];
userlist[0]=”1”;
userlist[1]=”2”;
//传递user对象查询用户列表
List<User>list = userMapper.selectUserByArray(userlist);

转载于:https://www.cnblogs.com/sh086/p/8375791.html

Mybatis笔记 - SQL标签方法相关推荐

  1. 9.mybatis动态SQL标签的用法

    mybatis动态SQL标签的用法 动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦 ...

  2. Mybatis动态sql标签说明

    一.简述 1️⃣config 文件常用标签 properties 标签:引入外部 properties 文件资源. settings 标签:设置 mybatis 全局行为. typeAlias 标签: ...

  3. mybatis的sql标签

    文章目录 一.choose 元素 二.where, trim, set元素: 1.where 元素: 2. trim 元素: 3.set 元素 三.foreach元素: 四.bind 元素 五.inc ...

  4. mybatis动态sql标签的使用

    动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦.拼接的时候要确保不能忘了必要的空格 ...

  5. Mybatis sql标签使用变量

    Mybatis sql标签使用变量 记录演示 Mybatis 中 sql 标签中使用变量的方法 <?xml version="1.0" encoding="UTF- ...

  6. Mybatis系列全解(八):Mybatis的9大动态SQL标签你知道几个?提前致女神!

    封面:洛小汐 作者:潘潘 2021年,仰望天空,脚踏实地. 这算是春节后首篇 Mybatis 文了~ 跨了个年感觉写了有半个世纪 - 借着女神节 ヾ(◍°∇°◍)ノ゙ 提前祝男神女神们越靓越富越嗨森! ...

  7. mybatis动态sql中的if、where、choose、trim、foreach方法

    mybatis笔记03 1.动态sql语句–>sql拼接 1.1 if方法 相当于el表达式中的if(){}语句 参数类型不同,if标签中test的参数是怎么说明的呢? 1)如果参数的类型是数字 ...

  8. mybatis sql标签_这谁顶得住?Mybatis 十八连环问

    来自:开源中国,作者:祖大俊 链接:https://my.oschina.net/zudajun/blog/747682 1.#{}和${}的区别是什么? 答:${}是Properties文件中的变量 ...

  9. Mybatis工作流程,附带mybatis的mapper文件和config配置文件模板。mapper文件和dao接口的关系——xml中的namespace和sql标签id命名要求。

    1. Mybatis工作流程 1.1 使用MySQL创建数据库girls并生成一个表boys,如下图. 1.2 创建该表对应的简单实体类Boys,如下图. 1.3 创建Dao接口以及和接口同名的map ...

  10. Mybatis的增删改查操作(包含动态代理,动态SQL标签,缓存,#与$的使用传入多参数,获取自增id等基本操作)

    我是在idea中创建的项目 首先项目大致目录:其中UserMapperImpl和UserTest是多余的,当做纪念所以没有删除. User pojo类: package com.ljh.pojo;pu ...

最新文章

  1. 今天分享个用Python爬虫爬取Bilibili弹幕的小例子解析
  2. CSS3 Animation(下)
  3. 我是架构师--设计模式-单例模式
  4. Boost智能指针——shared_ptr
  5. c#类和结构体的关系
  6. 为什么借助开源学习是最有效的?
  7. php获取url返回的json,【求助】本地页面如何取某个URL返回的json
  8. Keras---text.Tokenizer:文本与序列预处理
  9. mysql8.0其他机器访问_量子公司重大突破,量子机器学习实用化进程加速
  10. 设计模式【单例模式】
  11. 米哈游web前端面试题Js/Vue/浏览器原理等
  12. java统计误码率_MATLAB通信工具箱来计算误码率
  13. 英语语法基础02(句子成分)
  14. 判断7张扑克牌是否含有同花顺(5张同花顺子)
  15. CTFer成长计划训练营第二期挑战赛
  16. Python爬虫练习之花瓣网
  17. kali firefox gah. your tab just crashed. 更新Firefox
  18. 微软笔记本怎么装linux,微软正在为XO笔记本装Win/Linux双系统
  19. 安徽省计算机二级科目有哪些内容,计算机二级考试有哪些科目可以选择?
  20. CSS-弹性布局2-交叉轴

热门文章

  1. 想要转人工智能,程序员该如何学习?
  2. 为极致的视频体验而设计:facebook新一代存储平台Bryce Canyon架构
  3. 宣传失真,二手人生。
  4. pycharm pip安装_Python从入门到大师教程 | 一、搭建Python环境和安装Pycharm
  5. Oracle Siebel CRM技术的前景
  6. 方法、hadoop源码之JobQueueTaskScheduler-by小雨
  7. 十四 关于interrupt, interrupted, isInterrupted
  8. react-native 自定义 下拉刷新 / 上拉加载更多 组件
  9. 回顾Vue计算属性VS其他语法有感
  10. 程序员之路:python3+PyQt5+pycharm桌面GUI开发