Mybatis基础学习(三)—映射文件
一、输入映射
1.parameterType
指定输入参数的Java类,可以使用别名或者类的全限定名。它也可以接受基本数据类型、POJO对象、HashMap。
(1)基本数据类型

(2)POJO对象

(3)传递POJO包装对象
开发中通过pojo传递查询条件 ,查询条件是综合的查询条件,不仅包括用户查询条件还包括其它的查询条件(比如将用户购买商品信息也作为查询条件),这时可以使用包装对象传递输入参数。
UserQueryVo.java
public class UserQueryVO{
// 用户信息
private User user;
public User getUser(){
return user;
}
public void setUser(User user){
this.user = user;
}
}
UserMapper.xml

UserMapper.java

Test.java

(4)传递HashMap
map的key相当于POJO的属性。
UserMapper.xml

UserMapper.java

Test.java

结果:
User [id=25, username=陈小明, sex=2, birthday=Fri Jul 01 00:00:00 GMT+08:00 2016, address=长春市]
二、SQL标签
通过Mybatis提供的各种动态标签实现动态拼接sql,使得mapper映射文件在编写SQL时更加灵活,方便。常用动态SQL标签有:if、where、foreach。
1.if和where标签
if: 作为判断入参来使用的,如果符合条件,则把if标签体内SQL拼接上。注意:用if 标签判断是否为空时,不仅要判断null,也有判断空串""。
where: 会去掉条件中的第一个And符号。
案例一: 根据用户名和性别查询
UserMapper.xml
<!-- 标签的使用 -->
<select id="findUsersByNameAndSex" parameterType="userQueryVo" resultType="user">
SELECT * FROM user <!--wher标签:将后面第一个AND去掉,如果没有条件则把自己去掉 -->
<where>
<if test="user != null"> <if test="user.username != null and user.username != ''">
AND username LIKE '%${user.username}%'
</if> <if test="user.sex != null and user.sex != ''">
AND sex = #{user.sex}
</if> </if> </where> </select>
UserMapper.java
public interface UserMapper{
public User findUserById(int id);
public void saveUser(User user);
public List<User> findUserList(UserQueryVO uq);
public List<User> findUserByNameAndSex(HashMap hashMap);
public List<User> findUsersByNameAndSex(UserQueryVO vo);
}
Test.java
@Test
public void testFindUsersByNameAndSex(){ SqlSession sqlSession = sqlSessionFactory.openSession(); UserMapper mapper = sqlSession.getMapper(UserMapper.class); UserQueryVO vo = new UserQueryVO();
User u = new User();
// u.setUsername("小明");
// u.setSex("1");
vo.setUser(u); List<User> list = mapper.findUsersByNameAndSex(vo); for(User user : list){
System.out.println(user);
} sqlSession.close();
}
此时发出的Sql语句: SELECT * FROM user
去掉注释发出的Sql语句是:
Preparing: SELECT * FROM user WHERE username LIKE '%小明%' AND sex = ?
Parameters: 1(String)
2.sql片段
SQL片段的功能可以提高Sql的可重用性。
(1)定义
<!-- Sql片段: 可以将sql中任何部分放到sql片段中 建议: 不要将sql中的关键字放进去,比如 select where -->
<sql id="whereClause">
<if test="user != null"> <if test="user.username != null and user.username != ''">
AND username LIKE '%${user.username}%'
</if> <if test="user.sex != null and user.sex != ''">
AND sex = #{user.sex}
</if> </if>
</sql>
(2)引用SQL片段
<!-- 标签的使用 -->
<select id="findUsersByNameAndSex" parameterType="userQueryVo" resultType="user">
SELECT * FROM user <!--wher标签:将后面第一个AND去掉,如果没有条件则把自己去掉 -->
<where>
<!-- refid: Sql片段的ID -->
<include refid="whereClause"></include> </where> </select>
3.foreach标签
向sql传递数组或List时,mybatis使用foreach解析数组里的参数并拼接到Sql中。
UserMapper.xml

UserMapper.java

Test.java

输出的sql语句:
Preparing: SELECT * FROM user WHERE id IN ( ? , ? , ? , ? )
Parameters: 29(Integer), 31(Integer), 32(Integer), 33(Integer)
Mybatis基础学习(三)—映射文件的更多相关文章
- MyBatis 源码分析 - 映射文件解析过程
1.简介 在上一篇文章中,我详细分析了 MyBatis 配置文件的解析过程.由于上一篇文章的篇幅比较大,加之映射文件解析过程也比较复杂的原因.所以我将映射文件解析过程的分析内容从上一篇文章中抽取出来, ...
- Python入门基础学习 三
Python入门基础学习 三 数据类型 Python区分整型和浮点型依靠的是小数点,有小数点就是浮点型. e记法:e就是10的意思,是一种科学的计数法,15000=1.5e4 布尔类型是一种特殊的整形 ...
- Python基础学习三
Python基础学习三 1.列表与元组 len()函数:可以获取列表的元素个数. append()函数:用于在列表的最后添加元素. sort()函数:用于排序元素 insert()函数:用于在指定位置 ...
- Mybatis基础学习(四)—关系映射
一.模型分析 user和orders user---->orders 一个用户可以创建多个订单,一对多. orders--->user 一个订单只由一个用户创建,一对一. orders ...
- Mybatis(三) 映射文件详解
前面说了全局配置文件中内容的详解,大家应该清楚了,现在来说说这映射文件,这章就对输入映射.输出映射.动态sql这几个知识点进行说明,其中高级映射(一对一,一对多,多对多映射)在下一章进行说明. 一.输 ...
- Mybatis学习—XML映射文件
总结自 Mybatis官方中文文档 Mapper XML 文件 MyBatis 的真正强大在于它的映射语句,也是它的魔力所在.由于它的异常强大,映射器的 XML 文件就显得相对简单.如果拿它跟具有相同 ...
- mybatis 学习三 关键文件解析
1: mybatis-config.xml <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYP ...
- 【spring boot】14.spring boot集成mybatis,注解方式OR映射文件方式AND pagehelper分页插件【Mybatis】pagehelper分页插件分页查询无效解决方法
spring boot集成mybatis,集成使用mybatis拖沓了好久,今天终于可以补起来了. 本篇源码中,同时使用了Spring data JPA 和 Mybatis两种方式. 在使用的过程中一 ...
- Mybatis基础学习(五)—缓存
一.概述 mybatis提供查询缓存,如果缓存中有数据就不用从数据库中获取,用于减轻数据压力,提高系统性能. 一级缓存是SqlSession级别的缓存.在操作数据库时需要 ...
随机推荐
- CMFCShellList和自定义ShellList结合使用,达到“直接浏览缩略图,双击打开图片”
在GOPaint的设计研究过程中,我一直希望能够实现这样的结果(A B C 3个步骤) 在我之前的博客里面,曾经有过缩略图显示的现就(http://www.cnblogs.com/jsxyhelu/p ...
- C# winform程序免安装.net framework在XP/win7/win10环境运行!
前文: 首先感谢群里的大神宇内流云 提供的anyexec for windows版本. 经过本人搭建虚拟机在xp环境 使用anyexec运行winfrom程序后,测试通过,如下是用的xp运行winfr ...
- Keepalived安装与配置
下载并解压Keepalived安装包到两台nginx所在的服务器 192.168.200.1 192.168.200.2 执行编译安装(安装目录设置为 /usr/local/kee ...
- spring中对象的注入方式
平常的java开发中,程序员在某个类中需要依赖其它类的方法,则通常是new一个依赖类再调用类实例的方法,这种开发存在的问题是new的类实例不好统一管理,spring提出了依赖注入的思想,即依赖类不由程 ...
- 【转】Java中关于异常处理的十个最佳实践
原文地址:http://www.searchsoa.com.cn/showcontent_71960.htm 导读:异常处理是书写强健Java应用的一个重要部分,Java许你创建新的异常,并通过使用 ...
- 【前端】:jQuery实例
前言: 今天2月最后一天,写一篇jQuery的几个实例,算是之前前端知识的应用.写完这篇博客会做一个登陆界面+后台管理(i try...) 一.菜单实例 最开始的界面: 点击菜单三后的界面: < ...
- Servlet支持上传多张图片
首先前端的表单是这个形式: <form target="_self" method="post" action="fileUploadMult ...
- C++ 11 学习1:类型自动推导 auto和decltype
Cocos 3.x 用了大量的C++ 11 的东西,所以作为一个C++忠实粉丝,有必要对C++ 11进行一个系统的学习. 使用C++11之前,一定要注意自己使用的编译器对C++11的支持情况,有些编译 ...
- React组件开发经典案例--todolist
点开查看代码 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <me ...
- x01.Weiqi.13: 鼎力推荐
鼎力推荐 : 点击后即可观看,小伙子讲的很有深度. 说到深度,自然离不了深度学习.AlphaGo 的横空出世,似乎很有学习的必要. MuGo: 点击下载后,发现是 python,自然免不了一番学习,好 ...