Mybatis学习-GetMybatisInMyHead
认知
MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。
最近在鹅厂实习,也是在工作需要什么就去学习什么,本篇博客是实习过程中学习Mybatis的一点总结和记录,目的是为了方便自己以后使用Mybatis。
操作基本流程
1、配置mybatis-config.xml文件
该文件是Mybatis的必备文件,当然也可以采取代码中set的方式,但是不推荐。
配置优化
这些配置都可以在中文文档中找到,这里主要是记录下使用到的配置
- 别名优化,避免使用全类名
- 属性优化,自动驼峰转换、日志工厂等等
- 单独配置数据库连接配置文件..........
2、编写工具类,获取SqlSession
过程:SqlSessionFactoryBuilder -> SqlSessionFactory -> SqlSession
该方法应该编写为一个静态方法,用于不断获取SqlSession连接。获取的连接可以指定是否自动提交
同时这里可以看到SqlSessionFactory明显是单例模式,SqlSession是工厂模式。
3、编写需要的POJO和对应的POJOMapper(inteface)
这里就是Mybatis的好处了,可以将数据库查询出来的数据直接匹配到Java普通对象上去。
lombak插件
对于POJO类,需要编写属性名、无参构造方法,[有参构造方法],Getter和Setter方法以及toString方法。可以采用lombak插件进行简化代码编写,通过@Data和@NoArgsConstructor和@AllArgsConstructor来自动生成方法,只需要编写属性名即可。
4、编写POJOMapper.xml或者注解方式
这里就是实现POJOMapper中定义的方法,复杂的语句或者结果集映射最好采用.xml方式,简单的语句采用@注解方式即可。
.xml 方式
在这种方式下能使用Mybatis功能更多,同时也更加灵活
ResultMap结果集映射
- 简单的结果集映射(一对一):仅仅是修改字段和SQL查询出来的字段不一致的情况。
- 复杂的结果集映射(多对一):查询出来的数据字段对应着一个对象,但是该对象包含着另外一种对象,这时候就要使用到association标签,例如练习代码中多位学生对应着一位老师,每个学生对象中包含着老师对象。
- 复杂的结果集映射(一对多):查询出来的数据表示着一个对象,但是该对象包含着另外一种对象的集合,这时候就要使用到collection标签,例如练习代码中一位老师对应着多位学生,每个老师对象中包含着学生对象的集合。
使用复杂结果集映射可以采用两种方式(例子见练习代码mybatis-05):
- 子查询的方式:利用父查询的某字段查询出关联对象的信息输出,这种方式SQL代码简单但是.xml文件逻辑复杂
- 联表查询的方式:直接利用join的方式写出对应的SQL代码,然后在.xml文件中写出查询字段的结果映射即可。
动态SQL
动态SQL的目的是减少在Java代码的SQL语句的逻辑判断拼接和避免重复SQL(重复指的是仅仅只是where或者是set不同)的编写(例子见练习代码mybatis-06)。
- <if 标签 类似于if
- <choose <when <otherwise 标签 类似于switch
- <where <set 标签 是<trim标签的特殊情况,可以用来代替SQL语句中where和set关键字
- <sql <include 标签 代码片段,可以使用相同的代码片段
- <foreach 标签,生成一段可以控制开头符号、结尾符号和分隔符的SQL语句
注解方式
在这种方式下能使用基本的SQL语句和映射
- @Insert(插入SQL)
- @Delete(删除SQL)
- @Update(更新SQL)
- @Select(查询SQL)
- @Parm(字段别名)
5、注册Mapper
在mybatis-config文件中注册mapper,有三种方式:
- resource:指定.xml文件的路径,如果只采用了注解的方式,那么就不能用该方式注册Mapper
- package:指定.xml文件包名,必须要保证POJOMapper和POJOMapper.xml在一包下,同时如果只采用了注解方式没有问题。
- class:指定注册Mapper的全类名,必须要保证POJOMapper和POJOMapper.xml在一包下同时如果只采用了注解方式没有问题。
6、测试
Mybatis缓存
一级缓存,会话级缓存,默认开启不可关闭。增删改操作会刷新缓存,除非设置不刷新
二级缓存,Mapper级缓存,会话关闭时一级缓存刷写到二级缓存中,
查询顺序:二级缓存 -> 一级缓存 -> 数据库
Mybatis学习-GetMybatisInMyHead的更多相关文章
- MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作(转载)
本文转载自:http://www.cnblogs.com/jpf-java/p/6013540.html 上一篇博文MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybati ...
- MyBatis学习总结(八)——Mybatis3.x与Spring4.x整合(转载)
孤傲苍狼 只为成功找方法,不为失败找借口! MyBatis学习总结(八)--Mybatis3.x与Spring4.x整合 一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: m ...
- MyBatis学习总结(七)——Mybatis缓存(转载)
孤傲苍狼 只为成功找方法,不为失败找借口! MyBatis学习总结(七)--Mybatis缓存 一.MyBatis缓存介绍 正如大多数持久层框架一样,MyBatis 同样提供了一级缓存和二级缓存的 ...
- (原创)mybatis学习二,spring和mybatis的融合
mybatis学习一夯实基础 上文介绍了mybatis的相关知识,这一节主要来介绍mybaits和spring的融合 一,环境搭建 1,jar包下载,下载路径为jar包 2,将包导入到java工程中 ...
- (原创)mybatis学习一,夯实基础
一,what?(是什么) MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可 ...
- MyBatis学习--简单的增删改查
jdbc程序 在学习MyBatis的时候先简单了解下JDBC编程的方式,我们以一个简单的查询为例,使用JDBC编程,如下: Public static void main(String[] args) ...
- MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作
上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对u ...
- 【Todo】Mybatis学习-偏理论
之前写过好几篇Mybatis相关的文章: http://www.cnblogs.com/charlesblc/p/5906431.html <SSM(SpringMVC+Spring+Myba ...
- MyBatis学习系列三——结合Spring
目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring MyBatis在项目中应用一般都要结合Spring,这一章主要把MyBat ...
随机推荐
- 『动善时』JMeter基础 — 3、JMeter插件管理
JMeter是一个Java开发的开源软件,开源的软件有一个好处,就是会有很多第三方开发出来的插件,使得JMeter在处理某一些功能的时候更加的方便.并且这些插件拿过来就可以使用,完全免费的. 我们安装 ...
- 洛谷P1307 数字反转
题目描述 给定一个整数,请将该数各个位上数字反转得到一个新数.新数也应满足整数的常见形式,即除非给定的原数为零,否则反转后得到的新数的最高位数字不应为零(参见样例2). 输入输出格式 输入格式: 输入 ...
- Android so库文件的区节section修复代码分析
本文博客地址:http://blog.csdn.net/qq1084283172/article/details/78818917 一.Android so库文件的节表secion修复方案整理 1.简 ...
- Python小游戏 -- 猜单词
Python初学者小游戏:猜单词 游戏逻辑:就像我们曾经英语学习机上的小游戏一样,电脑会从事先预置的词库中抽取单词,然后给出单词的字母数量,给定猜解次数,然后让玩家进行猜测,并给出每次猜测的正确字母与 ...
- 后渗透阶段之基于MSF的内网主机探测
当我们通过代理可以进入某内网,需要对内网主机的服务进行探测.我们就可以使用MSF里面的内网主机探测模块了. 在这之前,先修改 /etc/proxychains.conf ,加入我们的代理. 然后 pr ...
- Windowsw核心编程 第13章 Windows内存结构
第1 3章 Wi n d o w s的内存结构 13.1 进程的虚拟地址空间 每个进程都被赋予它自己的虚拟地址空间.对于 3 2位进程来说,这个地址空间是4 G B,因为3 2位指针可以拥有从0 x ...
- mongo中常用的命令
命令使用mongo shell 执行 1.mongo中增加新字段 mongo shell 进入后执行use table选中要添加字段的库 db.getCollection('表名').update({ ...
- centos 7.6 安装最新版docker 19.03
systemctl stop docker rpm -qa | grep docker 看到那个删除那个yum erase docker \ docker-client \ docker-client ...
- OOP第一章总结
经过了三周的OO,尽管过程不太轻松,但是有所得还是值得欣慰的事! (1)程序结构 第一次作业: UML类图如下,第一次作业在结构上并没有太多面向对象的思想,只是简单的分类,一个运行类,两个对象类,预处 ...
- 『动善时』JMeter基础 — 23、JMeter中使用“用户自定义变量”实现参数化
目录 1.用户自定义变量介绍 2.使用"用户自定义变量"实现参数化 (1)测试计划内包含的元件 (2)数据文件内容 (3)测试计划界面内容 (4)线程组元件内容 (5)CSV数据文 ...