动力节点-王妈妈Springboot教程(四)ORM操作MySQL

第四章 ORM 操作 MySQL

官方下载地址

动力节点springboot资料

视频观看地址

https://www.bilibili.com/video/BV1XQ4y1m7ex

讲解 MyBatis 框架, 读写 MySQL 数据。通过 SpringBoot +MyBatis 实现对数据库学生表的查询操作。

数据库参考: springboot.sql 脚本文件

创建数据库:数据库 springboot,指定数据库字符编码为 utf-8

插入数据

4.1 创建 Spring Boot 项目

项目名称: 015-springboot-mybatis

使用@Mapper 注解

➢   pom.xml

加入 resources 插件

➢   配置数据源: application.properties

➢   创建数实体 bean, dao 接口, mapper 文件

➢   实体类

➢   创建 Dao 接口

➢   mapper 文件:

➢   service 接口

➢   service 接口实现类

returnstudent;  

}

➢   controller 类

启动 Application 类, 浏览器访问http://localhost:9090/myboot/query

4.2 @MapperScan

在 Dao 接口上面加入@Mapper, 需要在每个接口都加入注解。 当 Dao 接口多的时候不方便。

可以使用如下的方式解决。

主类上添加注解包扫描: @MapperScan("com.bjpowernode.dao")

新建 Spring Boot 项目 : 016-springboot-mybatis2

项目的代码同上面的程序,修改的位置:

1.去掉 StudentMapper 接口的上面的@Mapper 注解

2.在主类上面加入 @MapperScan()

4.3 mapper 文件和 java 代码分开管理

这种方式比较推荐, mapper 文件放在 resources 目录下, java 代码放在 src/main/java。

实现步骤:

➢   在resources 创建自定义目录,例如mapper, 存放 xml 文件

➢   把原来的 xml 文件剪切并拷贝到 resources/mapper 目录

➢   在application.properties配置文件中指定映射文件的位置, 这个配置只有接口和映 射文件不在同一个包的情况下,才需要指定。

➢  运行主类,  浏览器测试访问

4.4 事务支持

Spring Boot 使用事务非常简单,底层依然采用的是 Spring 本身提供的事务管理

➢    在入口类中使用注解 @EnableTransactionManagement 开启事务支持

➢    在访问数据库的 Service 方法上添加注解 @Transactional 即可

通过 SpringBoot +MyBatis 实现对数据库学生表的更新操作,在 service 层的方法中构建 异常,查看事务是否生效。

创建项目: 018-springboot-transaction

项目可以在 MyBatis 项目中修改。

实现步骤:

1. pom.xml

2. 修改 StudentService,在 addStudent()方法中抛出异常

3. 在 Application 主类上, @EnableTransactionManagement 开启事务支持 @EnableTransactionManagement 可选,但是@Service 必须添加事务才生效

4. 测试应用,  数据没有添加成功

5. 注释掉 StudentServiceImpl 上的@Transactional 测试。数据添加成功

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

推荐阅读更多精彩内容