Mybatis【配置文件】就是这么简单
配置文件和映射文件还有挺多的属性我还没有讲的,现在就把它们一一补全
映射文件
在mapper.xml文件中配置很多的sql语句,执行每个sql语句时,封装为MappedStatement对象,mapper.xml以statement为单位管理sql语句
Statement的实际位置就等于namespace+StatementId
占位符
在Mybatis中,有两种占位符
#{}
解析传递进来的参数数据${}
对传递进来的参数原样拼接在SQL中
主键生成策略
如果我们在Hibernate中,当我们插入数据的时候,我们是可以选择是UUID策略的...
那么在Mybatis是怎么做的呢??
UUID
<!-- mysql的uuid生成主键 --><insert id="insertUser" parameterType="cn.itcast.mybatis.po.User"><selectKey keyProperty="id" order="BEFORE" resultType="string">select uuid()</selectKey>INSERT INTO USER(id,username,birthday,sex,address) VALUES(#{id},#{username},#{birthday},#{sex},#{address})</insert>
主键返回
如果我们一般插入数据的话,如果我们想要知道刚刚插入的数据的主键是多少,我们可以通过以下的方式来获取
需求:
- user对象插入到数据库后,新记录的主键要通过user对象返回,通过user获取主键值。
解决思路:
- 通过LAST_INSERT_ID()获取刚插入记录的自增主键值,在insert语句执行后,执行select LAST_INSERT_ID()就可以获取自增主键。
mysql:
<insert id="insertUser" parameterType="cn.itcast.mybatis.po.User"><selectKey keyProperty="id" order="AFTER" resultType="int">select LAST_INSERT_ID()</selectKey>INSERT INTO USER(username,birthday,sex,address) VALUES(#{username},#{birthday},#{sex},#{address})</insert>
oracle:
实现思路:
- 先查询序列得到主键,将主键设置到user对象中,将user对象插入数据库。
<!-- oracle在执行insert之前执行select 序列.nextval() from dual取出序列最大值,将值设置到user对象 的id属性--><insert id="insertUser" parameterType="cn.itcast.mybatis.po.User"><selectKey keyProperty="id" order="BEFORE" resultType="int">select 序列.nextval() from dual</selectKey>INSERT INTO USER(id,username,birthday,sex,address) VALUES( 序列.nextval(),#{username},#{birthday},#{sex},#{address})</insert>
resultMap
有的时候,我们看别的映射文件,可能看不到以下这么一段代码:
<resultMap id="userListResultMap" type="user" ><!-- 列名id_,username_,birthday_id:要映射结果集的唯 一标识 ,称为主键column:结果集的列名property:type指定的哪个属性中--><id column="id_" property="id"/><!-- result就是普通列的映射配置 --><result column="username_" property="username"/><result column="birthday_" property="birthday"/></resultMap>
因为,如果我们的数据表的字段和JavaBean的属性名称是相同时,我们就不用上面那段代码了。Mybatis会自动帮我们把返回的结果进行封装成JavaBean
那当我们数据表的字段和JavaBean的属性名称不是相同时,我们就需要使用resultMap,也就是上面那段代码
- 当然了,在正常情况下列名和JavaBean的属性名一般都是不同的,因此还是需要resultMap的。
resultMap和resultType区别
resultType :指定输出结果的类型(pojo、简单类型、hashmap..),将sql查询结果映射为java对象 。
- 使用resultType注意:sql查询的列名要和resultType指定pojo的属性名相同,指定相同 属性方可映射成功,如果sql查询的列名要和resultType指定pojo的属性名全部不相同,list中无法创建pojo对象的。
resultMap:将sql查询结果映射为java对象。
- 如果sql查询列名和最终要映射的pojo的属性名不一致,使用resultMap将列名和pojo的属性名做一个对应关系 (列名和属性名映射配置)
使用resultMap
<resultMap id="userListResultMap" type="user" ><!-- 列名id_,username_,birthday_id:要映射结果集的唯 一标识 ,称为主键column:结果集的列名property:type指定的哪个属性中--><id column="id_" property="id"/><!-- result就是普通列的映射配置 --><result column="username_" property="username"/><result column="birthday_" property="birthday"/></resultMap>
resultType和resultMap用法总结
resultType:
作用:
- 将查询结果按照sql列名pojo属性名一致性映射到pojo中。
场合:
- 常见一些明细记录的展示,将关联查询信息全部展示在页面时,此时可直接使用resultType将每一条记录映射到pojo中,在前端页面遍历list(list中是pojo)即可。
resultMap:
- 使用association和collection完成一对一和一对多高级映射。
association:
作用:
- 将关联查询信息映射到一个pojo类中。
场合:
- 为了方便获取关联信息可以使用association将关联订单映射为pojo,比如:查询订单及关联用户信息。
collection:
作用:
- 将关联查询信息映射到一个list集合中。
场合:
- 为了方便获取关联信息可以使用collection将关联信息映射到list集合中,比如:查询用户权限范围模块和功能,可使用collection将模块和功能列表映射到list中。
Collection在前面好像并没有用过,下面就看一下它的用法:
Order与OrderDetails关系
package cn.itcast.mybatis.po;import java.io.Serializable;
import java.util.Date;
import java.util.List;public class Orders implements Serializable {private Integer id;private Integer userId;private String number;private Date createtime;private String note;//关联用户信息private User user;//订单明细private List<Orderdetail> orderdetails;public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public Integer getUserId() {return userId;}public void setUserId(Integer userId) {this.userId = userId;}public String getNumber() {return number;}public void setNumber(String number) {this.number = number == null ? null : number.trim();}public Date getCreatetime() {return createtime;}public void setCreatetime(Date createtime) {this.createtime = createtime;}public String getNote() {return note;}public void setNote(String note) {this.note = note == null ? null : note.trim();}public User getUser() {return user;}public void setUser(User user) {this.user = user;}public List<Orderdetail> getOrderdetails() {return orderdetails;}public void setOrderdetails(List<Orderdetail> orderdetails) {this.orderdetails = orderdetails;} }
SQL语句
<!-- 一对多查询使用reusltMap完成查询订单关联查询订单明细--><select id="findOrderAndOrderDetails" resultMap="orderAndOrderDetails" >SELECT orders.*,user.username,user.sex ,orderdetail.id orderdetail_id,orderdetail.items_num,orderdetail.items_idFROMorders,USER,orderdetailWHERE orders.user_id = user.id AND orders.id = orderdetail.orders_id</select>
resultMap
<!-- 一对多,查询订单及订单明细 --><resultMap type="orders" id="orderAndOrderDetails" extends="ordersUserResultMap"><!-- 映射订单信息,和用户信息,这里使用继承ordersUserResultMap --><!-- 映射订单明细信息 property:要将关联信息映射到orders的哪个属性中ofType:集合中pojo的类型--><collection property="orderdetails" ofType="cn.itcast.mybatis.po.Orderdetail"><!-- id:关联信息订单明细的唯 一标识property:Orderdetail的属性名--><id column="orderdetail_id" property="id"/><result column="items_num" property="itemsNum"/><result column="items_id" property="itemsId"/></collection></resultMap>
一般地使用resultMap会多一点。
Mybatis映射文件处理特殊字符
第一种方法:
- 用了转义字符把>和<替换掉,然后就没有问题了。
- SELECT * FROM test WHERE 1 = 1 AND start_date <= CURRENT_DATE AND end_date >= CURRENT_DATE
第二种方法:
- <![CDATA[ ]]>
配置文件
别名
typeAliases别名:
自定义别名:
<!-- 定义 别名 --><typeAliases><!--单个别名的定义alias:别名,type:别名映射的类型 --><!-- <typeAlias type="cn.itcast.mybatis.po.User" alias="user"/> --><!-- 批量别名定义指定包路径,自动扫描包下边的pojo,定义别名,别名默认为类名(首字母小写或大写)--><package name="cn.itcast.mybatis.po"/></typeAliases>
Mapper加载
<mappers><!-- 通过resource引用mapper的映射文件 --><mapper resource="sqlmap/User.xml" /><!-- <mapper resource="mapper/UserMapper.xml" /> --><!-- 通过class引用mapper接口 class:配置mapper接口全限定名要求:需要mapper.xml和mapper.java同名并且在一个目录 中--><!-- <mapper class="cn.itcast.mybatis.mapper.UserMapper"/> --><!-- 批量mapper配置 通过package进行自动扫描包下边的mapper接口,要求:需要mapper.xml和mapper.java同名并且在一个目录 中--><package name="cn.itcast.mybatis.mapper"/></mappers>
延迟加载
在进行数据查询时,为了提高数据库查询性能,尽量使用单表查询,因为单表查询比多表关联查询速度要快。
如果查询单表就可以满足需求,一开始先查询单表,当需要关联信息时,再关联查询,当需要关联信息再查询这个叫延迟加载。
在Mybatis中延迟加载就是在resultMap中配置具体的延迟加载..
在Mybatis的文件中配置全局延迟加载
<!-- 全局配置参数 --><settings><!-- 延迟加载总开关 --><setting name="lazyLoadingEnabled" value="true" /> <!-- 设置按需加载 --><setting name="aggressiveLazyLoading" value="false" /></settings>
延迟加载测试
当需要用户时调用 Orders类中的getUser()方法执行延迟加载 ,向数据库发出sql。
由于是对User进行延迟加载,那么我们只要查询Orders相关的信息即可了
<!-- 一对一查询延迟加载开始只查询订单,对用户信息进行延迟加载 --><select id="findOrderUserListLazyLoading" resultMap="orderCustomLazyLoading">SELECT orders.*FROMorders</select>
使用resultMap来配置延迟加载
<!-- 一对一查询延迟加载 的配置 --><resultMap type="orders" id="orderCustomLazyLoading"><!-- 完成了订单信息的映射配置 --><!-- id:订单关联用户查询的唯 一 标识 --><id column="id" property="id" /><result column="user_id" property="userId" /><result column="number" property="number" /><result column="createtime" property="createtime" /><result column="note" property="note" /><!--配置用户信息的延迟加载select:延迟加载执行的sql所在的statement的id,如果不在同一个namespace需要加namespacesql:根据用户id查询用户信息【column就是参数】column:关联查询的列property:将关联查询的用户信息设置到Orders的哪个属性 --><!--当需要user数据的时候,它就会把column所指定的user_id传递过去给cn.itcast.mybatis.mapper.UserMapper.findUserById作为参数来查询数据--><association property="user"select="cn.itcast.mybatis.mapper.UserMapper.findUserById" column="user_id"></association></resultMap>
总结
- 在程序中调用的SQL语句是由映射文件的命令空间+sql片段的id所组成的。它内部会生成一个Statement对象的。
- 在使用别名的时候,可以指定包名,在使用总配置文件加载映射文件时,也可以指定包名。
- 主键如果需要返回的话,使用selectKey 标签即可。UUID也可以返回。在Oracle的话,是使用序列来返回自动增长的主键的。
- 占位符有两种,一种是解析传递进来的参数数据、一种是原样输出传递进来的数据。
如果文章有错的地方欢迎指正,大家互相交流。习惯在微信看技术文章,想要获取更多的Java资源的同学,可以关注微信公众号:Java3y
Mybatis【配置文件】就是这么简单相关推荐
- mybatis分页插件pageHelper简单实用
转载自 http://blog.csdn.net/Smile_Miracle/article/details/53185655 工作的框架spring springmvc mybatis3 首先使用分 ...
- Mybatis配置文件注释
1,Mybatis配置文件注释 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE confi ...
- Mybatis系列全解(四):全网最全!Mybatis配置文件XML全貌详解
封面:洛小汐 作者:潘潘 做大事和做小事的难度是一样的.两者都会消耗你的时间和精力,所以如果决心做事,就要做大事,要确保你的梦想值得追求,未来的收获可以配得上你的努力. 前言 上一篇文章 <My ...
- mybatis配置文件解析
mybatis配置文件解析 mybatis核心配置文件`mybatis-config.xml文件. mybatis的配置文件包含了会深深影响mybatis行为的设置和属性信息. 能配置的内容: con ...
- 2 了解MyBatis配置文件
2.1 认识配置文件: 介绍 MyBatis的配置文件中包含了影响MyBatis行为和属性的信息,控制MyBatis的整体运行方式.配置文件中主要配置数据源[驱动类,URL,账号,密码],事务管理,加 ...
- mybatis 配置文件报错:Referenced file contains errors(file:/D:/config/ mybatis-3-mapper.dtd).
JAVA就业套餐课:https://edu.csdn.net/combo/detail/1230 在项目搭建过程中,配置Mybatis配置文件时,出现错误:在UserMapper.xml头文件出现 ...
- MyBatis之优化MyBatis配置文件中的配置
MyBatis之优化MyBatis配置文件中的配置 2017/9/30 MyBatis配置文件很重要,首先我们来看看MyBatis配置文件中的内容和顺序: 文件目录结构如下: 1.<proper ...
- MyBatis 配置文件 用户密码加密存储
文章目录 1. 创建db.properties 2. 配置mybatis-config.xml 3. 加解密工具类 4. 加解密依赖 5. 创建SqlSessionFactoryUtil类 6. db ...
- mybatis 配置文件中,collection 和 association 的对应关系
mybatis 配置文件中,collection 和 association 的对应关系 如下图所示:
- SMM学习22:MyBatis配置文件起别名typeAliases
目录 创建数据库 连接数据库 导入坐标pom.xml 编写mybatis.xml配置文件 编写日志配置文件 编写sql映射文件UserMapper.xml 创建UserMapper接口 创建pojo ...
最新文章
- java实现收货7天发通知,Java实训的第7天
- 生物医学大数据处理研究探讨
- C#操作xml文件入门
- Redmonk 发布 Java 框架流行度调研结果
- python发送qq消息linux_python 调用qq邮箱 linux 执行每天自动发送邮件
- 简单的解决达梦数据库查询 dm.jdbc.driver.DmdbNClob@1064bb3e 问题
- DispatcherServlet和Spring应用上下文初始化详解
- 计算机的超级终端程序无法使用,超级终端,教您win7怎么添加超级终端
- Vbox安装增强功能
- 斯托克斯定理,de Rham上同调习题
- 什么是 NAS? 为什么要用 NAS?有什么好玩的功能?
- java406错误_Springmvc报406错误(Not Acceptable)的有效解决方法
- html5 app 原理,浅析开发html5 app的三大优势
- 如何在 Bios 中更改硬盘模式?
- 如何调整gif动图的速度?1分钟在线调节gif动图速度
- [PAL规范]SAP HANA PAL 数据处理四分位间距检测Inter-quartile Range Test编程规范IQRTEST...
- python实现简单的多人聊天功能
- 【点云系列】 场景识别类导读
- flask部署阿里云服务器,公网ip访问不了(一些问题及解答)
- php面向对象--php面向对象ppt
热门文章
- C++11中头文件atomic的使用
- 结构体中最后一个成员为[0]或[1]长度数组(柔性数组成员)的用法
- 【C++】new和malloc的区别
- apn java_android设置移动联通电信wap接入点
- easyexcel生成excel_阿里JAVA解析Excel工具easyexcel
- HTML5文档结构主体结构 语义结构,html5组织文档结构.pdf
- linux里运行windows,在Linux上运行Windows应用程序
- 吸顶wifi_分享 | 酒店WiFi网络的三种部署模式
- 加密解密php,PHP实现的加密解密处理类
- python查看目录下的文件_Python——查看目录下所有的目录和文件