当前位置: 首页 > 编程日记 > 正文

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

相关文章:

cto denalil

Denali使用准虚拟化技术来提高x86电脑上虚拟机的性能。Denali的虚拟机为因特网服务专门支持了最小化的操作系统。 系统可以运行上千虚拟机。Xen与Denali不同&#xff0c;因为它试图运行适当数量的完整操作系统&#xff0c;而非大量轻量级操作系统。转载于:https://blog.51cto.c…

Redis学习笔记 - 数据类型与API(1)Key

Redis学习笔记 - 数据类型与API&#xff08;1&#xff09;Key Key相关命令 1. 常用命令 命令含义时间复杂度keys查找所有符合给定模式 pattern 的 keyO(N)&#xff0c; N 为数据库中 key 的数量dbsize计算key的总数O(1)exists检查key是否存在O(1)del删除指定的key-valueO(1)exp…

【Qt】enum和QString的相互

使用Q_ENUM注册enum Q_ENUM使用元对象系统meta-object来注册,因此在enum所在的类中必须包含宏Q_OBJECT或者Q_GADGET。 例子如下 class MyClass : public QObject{Q_OBJECTpublic:MyClass(QObject *parent = 0);~MyClass();enum Priority { High, Low, VeryHigh, VeryLow };Q_…

Gmail全球大规模宕机

整理 | 非主流出品 | AI科技大本营&#xff08;ID: rgznai100&#xff09;今天&#xff08;3 月 13 日&#xff09;&#xff0c;Google 的多项服务在全球范围内出现了不同程度的宕机&#xff0c;包括 Gmail、Google Drive、 Hangouts、谷歌地图等。受影响最大的是拥有超 10 亿用…

搭建域控服务器

作业环境 服务器端(VirtualBox VM) 操作系统&#xff1a;Windows Server 2003 Enterprise Edition SP2 IPAddress&#xff1a;192.168.1.1/255.255.255.0 Gateway&#xff1a;null 客户端(VirtualBox VM) 操作系统&#xff1a;Windows XP SP3 IPAddress&#xff1a;192.168.1.2…

【Git】ubuntu安装git

sudo apt-get install git 图形界面的&#xff1a;sudo apt-get install git-gui 查看ssh服务是否启动 sudo ps -e | grep ssh 如果没有启动执行如下命令&#xff1b; sudo service ssh start 如果没有ssh&#xff0c;使用如下命令安装 sudo apt-get install ssh

Composer 篇

学习网站Composer 中文网 资源包 Packagist Packagist / Composer 中国全量镜像如何安装 Composer下载 Composer安装前请务必确保已经正确安装了PHP。打开命令行窗口并执行php -v查看是否正确输出版本号。打开命令行并依次执行下列命令安装最新版本的 Composer&#xff1a;php …

西工大开源拥挤人群数据集生成工具,大幅提升算法精度 | CVPR 2019

作者 | 周强&#xff08;CV君&#xff09;转载自 我爱计算机视觉&#xff08;公众号id&#xff1a;aicvml&#xff09;近年来&#xff0c;因为拥挤人群计数在视频监控、公共安全方面的应用广泛&#xff0c;引起了不少学者的关注。简单说来这个任务就是给定图像&#xff0c;返回…

getElementById 不能取得visible=false 的控件解决方法

想要绑定textbox的回车事件到一个按钮上&#xff0c;但不想显示这个按钮&#xff0c;如果你把这个button的visible设置为false,那么你使用 getElementById是获取不到的&#xff0c;或者说取到的为空。这是因为Visiblefalse&#xff0c;在编译后&#xff0c;该控件在页面上不显示…

【Git】在本地创建git库管理自己的代码

1、创建本地库 git init . 新建库 git config --global user.email “hello163.com” git config --global user.name “laoer” git config --global core.editor vim //将默认编辑器由nano更改为vim 2、提交 2.1 git add . 将当前目录下所有文件添加到提交缓冲区 2.2 git …

“智慧血联网平台”亮相军民融合技术装备博览会

该平台可实现血液全程跟踪溯源&#xff0c;为大众提供安全、透明、便捷的用血服务。 一个打造智慧化血液管理新模式的血联网平台最近亮相第三届中国军民融合技术装备博览会。该平台可实现血液全程跟踪溯源&#xff0c;为大众提供安全、透明、便捷的用血服务。 此次博览会以“聚…

AI专利之争:小米超华为,国家电网才是大Boss?

作者 | 一一编辑 | 琥珀出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;以往相关机构发布 AI 专利数量排行榜时&#xff0c;如果表明“中国在 AI 专利申请数量上已经超过美国&#xff0c;中国在 AI 技术实力上已在国际上遥遥领先”&#xff0c;这类榜单会招致对中国科…

SLF4J 的几种实际应用模式--之二:SLF4J+Logback

前面讲的 SLF4J 的用法之一是 SLF4JLog4J&#xff0c;而这里要推出的组合是 SLF4JLogBack。不用 Log4J&#xff1f;难道还有比 Log4J 更好的日志实现吗&#xff1f;是的&#xff0c;答案就是 LogBack。假如你知道 LogBack 和 Log4J 是同出一位大师之手&#xff0c;你就不会觉得…

10行Python,搭建一个游戏AI | 视频教程

昨天为大家推荐了三个Python视频&#xff0c;包含&#xff1a;《利用Python&#xff0c;用4分钟时间搭建一个情感分析系统》、《7行Python代码&#xff0c;搭建一个可以识花的机器学习APP》、《10行Python&#xff0c;搭建一个可以自动作曲的神经网络》&#xff0c;今天营长再为…

ABAP git客户端

Jerry习惯把自己写的小程序放到自己的github上&#xff1a;https://github.com/i042416 对于写的ABAP程序&#xff0c;需要先把SAPGUI里的代码手动拷贝到本地&#xff0c;然后用git客户端push到github上。 但是其实可以直接在SAPGUI里通过一个ABAP实现的git客户端将代码push到g…

【Git】git 与远程库交互

一、远程操作 1、克隆 git clone <url> 2、提交 git add &#xff1a;添加 git commit -m “修改信息” &#xff1a;提交到本地 git branch -a &#xff1a;查看所有分支&#xff0c;红色的是远程分支 git fetch &#xff1a;获取远程分支 git diff HEAD FETCH_HEAD…

[轉]在jQuery1.5中使用deferred对象 - 拿着放大镜看Promise

http://www.cnblogs.com/sanshi/archive/2011/03/11/1981789.html 不錯的JS方面的文章 三生石上

拼多多成立技术顾问委员会,陆奇将领导相关工作

整理 | 琥珀出品 | AI科技大本营&#xff08;公众号id&#xff1a;rgznai100&#xff09;美国东部时间 3 月 13 日上午&#xff0c;拼多多&#xff08;NASDAQ&#xff1a;PDD&#xff09;公布了截止 2018 年 12 月 31 日的第四季度和全年年的未经审计财务业绩。拼多多创始人、C…

【linux】Valgrind工具集详解(一):简介

一、Valgrind概述 Valgrind是用于构建动态分析工具的仪器框架。它附带了一组工具&#xff0c;每个工具都执行某种调试&#xff0c;分析或类似任务&#xff0c;可帮助您改进程序。Valgrind的架构采用模块化设计&#xff0c;因此可以轻松创建新工具&#xff0c;而不会干扰现有结…

An internal error occurred during: Launching xxx on WebLogic10.x.

An internal error occurred during: "Launching xxx on WebLogic10.x". java.lang.NullPointerException 蕃薯耀 2018年3月15日 http://www.cnblogs.com/fanshuyao/ 一、问题描述&#xff1a; Myeclipse 将项目部署web服务器报错&#xff1a; An internal error oc…

Android -- TextView与EditText 同步显示

Android -- TextView与EditText 同步显示文章分类:JavaEye方法一.利用View.OnKeyListener"同步"显示Java代码 EditText myEdit (EditText)findViewById(R.id.myEdit); TextView myText (TextView)findViewById(R.id.myText); myEdit.setOnKeyListener(new Edit…

【linux】Valgrind工具集详解(二):入门

一、使用valgrind 1、安装 安装超级简单: sudo apt-get install valgrind 2、使用 运行valgrind -h可以查看详细使用方法,命令格式如下: valgrind [valgrind -h中的选项] 待测程序 [待测程序的命令行参数列表]最重要的选项是–tool决定运行哪种Valgrind工具。 例如,使…

Spring Cloud - Feign调用问题

2019独角兽企业重金招聘Python工程师标准>>> 这两天在改造微服务远程调用方法时&#xff0c;由之前的RestTemplate方式&#xff0c;改为FeignClient方式。 遇到一个及其恶心的问题。 直接上错误提示&#xff1a; 这里面&#xff0c;最重要的一条是&#xff1a; 这个…

开源的Blink和Spark3.0,谁将称霸大数据领域?

来源 | 大数据技术与架构&#xff08;import_bigdata&#xff09;作者 | 王知无&#xff0c;阿里巴巴高级大数据开发工程师&#xff0c;先后在京东、阿里等大型互联网公司从事大数据平台、实时计算和离线计算中间件和业务平台开发。2018和2019年是大数据领域蓬勃发展的两年&…

Redis 集群部署及踩过的坑

本文目标 要在单台机器上搭建Redis集群&#xff0c;方式是通过不同的TCP端口启动多个实例&#xff0c;然后组成集群&#xff0c;同时记录在搭建过程中踩过的坑。 安装准备 centos版本&#xff1a;6.7 redis版本&#xff1a;3.2.3 安装方式&#xff1a;源码安装 服务器&#xff…

【linux】Valgrind工具集详解(三):打印信息说明

一、打印信息格式 Valgrind打印信息的格式如下,很容易和程序输出信息区分出来 == 进程ID ==Valgrind的打印信息二、打印到何处 1、打印到文件描述符中 主要是设置打印到终端上,默认情况下为2(stderr标准错误输出)。如果要想打印到其他文件描述符(例如编号9),则可以指…

杨超越第一,Python第二

追星追到程序员们狂热得搞起了编程比赛&#xff0c;长这么大&#xff0c;这种应援架势真没见过。没错&#xff0c;说的就是你们的杨超越妹妹。近日百度贴吧吧主在杨超越吧发帖&#xff0c;呼吁要为自己的偶像组织第一届杨超越杯编程大赛&#xff0c;众粉丝呼应&#xff0c;随即…

SQL Server数据库错误9003(LSN无效)的处理方法

国内一些ERP、财务软件一般后台都使用SQL Server的数据库&#xff0c;SQL Server作为一个中大型数据库是不应该在桌面系统上运行的&#xff0c;小规模企业一般不使用专用服务器&#xff0c;大部分直接使用XP系统桌面引擎MSDE作为SQL数据库的后台服务。这种方案当然就谈不上什么…

新款Tesla最低仅售26.2万,马斯克终于凑齐了S3XY

作者 | 琥珀出品 | AI科技大本营&#xff08;公众号id&#xff1a;rgznai100&#xff09;北京时间 3 月 15 日上午许&#xff0c;整整等待了 20 分钟的特斯拉 Model Y 新品发布会终于开场。在台下观众的阵阵欢呼声中&#xff0c;台上的埃隆 马斯克显得神采奕奕。这次&#xff…

【linux】Valgrind工具集详解(四):抑制错误

一、什么是抑制错误 错误检查工具可以检测系统库中的许多问题,例如C库,它是随操作系统预安装的。这些错误无法修复,并且有很多,但不希望看到这些错误。如何屏蔽这样错误就叫做“抑制错误”。 二、使用方法 1、使用默认的抑制错误配置 valgrind参数为 –default-suppress…