MyBatis使用文档

为了方便 MyBatis 的使用,整理编写了一个 MyBatis 的例子,各种映射器、动态 SQL 的使用都可以在例子中找到,接下来我们详细描述项目的情况。

MyBatis 官网文档:http://www.mybatis.org/mybatis-3/zh/index.html

项目地址:https://gitee.com/yin_jw/demo.git

数据库表的模型关系:https://www.processon.com/view/link/5baf4a2ce4b0d4d65c1ca52a

结论
  1. resultMap 的级联操作不要使用
  2. 二级缓存不要使用

这两个功能只是看起来美好,实际使用起来很多坑。虽然 resultMap 的级联操作很坑,但是例子中还是简单实现了一下。

如何让实例跑起来
  1. 在数据库中建表,建表语句在的 db 目录
  2. 修改 application.yml 配置,通过 Application.java 类启动项目
配置

项目中没有使用 MyBatis 配置文件(mybatis-config.xml),项目使用了 Spring Boot 框架,简化了 MyBatis 的配置。下面介绍一下项目中各处的 MyBatis 配置内容。

  1. Spring Boot 配置文件(application-dev.yml)中的 MyBatis 配置,这些配置在项目启动的时候由 spring-boot-autoconfigure-1.5.9.RELEASE.jar、mybatis-spring-boot-autoconfigure-1.3.1.jar 负责加载,这就是 Spring Boot 的方便之处。
  1. Spring Boot 启动类(Application)中配置 dao 类的包名
  1. 增加了一个性别枚举的类型处理器(SexEnumTypeHandler),该类型处理器会在配置在 Mapper 映射文件(StudentMapper.xml)中,处理学生的性别数据。
映射器

参考 StudentMapper.xml 文件,各种元素的使用在里面都有详细的例子。简单的元素使用这里就不做详细介绍了,具体内容可以直接参考该 xml 文件。

  1. SQL映射文件的几个顶级元素

cache 和 cache-ref 有坑,不适合分布式服务,这里就不做介绍了,其实单节点服务也不建议使用,二级缓存是坑。

元素名称 描述 备注
select 查询语句 可以自定义参数,返回结果集等
insert 插入语句 执行后返回一个整数,代表插入的条数
update 更新语句 执行后返回一个整数,代表更新的条数
delete 删除语句 执行后返回一个整数,代表删除的条数
parameterMap 定义参数映射关系 即将被删除的元素,不建议大家使用
sql 允许定义一部分的SQL,然后在各个地方引用它 例如,一张表列名,我们可以一次定义,在多个SQL语句中使用
resultMap 用来描述从数据库结果集中来加载对象 它将提供映射规则
cache 给定命名空间的缓存配置
insert 其他命名空间缓存配置的引用
  1. 级联和延迟加载

在 application-dev.yml 配置文件中开启了全局延迟加载功能,例如我们取出学生信息,不会级联取出学生成绩和学生证信息,只有在访问学生成绩属性的时候 MyBatis 才会去发送 SQL 去取出学生成绩的信息。

注意:在代码中有两种级联方式,具体使用参考StudentMapper.xml

动态SQL
  1. MyBatis 的动态 SQL 包括以下几种元素
元素名称 描述 备注
if 判断语句 单条件分支判断
choose(when、otherwise) 相当于Java中的case when语句 多条件分支判断
trim(where、set) 辅助元素 用于处理一些SQL拼装问题
foreach 循环语句 在in语句等列举条件常用

具体元素的使用在StudentMapper.xml都有体现,大家一看就明白。如果对元素描述的不到位的,可以参考MyBatis的官网文档,链接在文档的最上方。

  1. 新增数据返回主键ID

这里提一下吧,也便于大家了解这方面的写法,我觉得框架的使用不需要记忆,只需要有个使用例子方便我们 Ctrl + c、Ctrl + v

最后

MyBatis 的插件使用属于高级篇没有在这里描述,后面有时间了,我再去了解一下 罒ω罒 罒ω罒 罒ω罒

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,126评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,254评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,445评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,185评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,178评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,970评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,276评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,927评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,400评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,883评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,997评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,646评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,213评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,204评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,423评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,423评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,722评论 2 345