哈喽各位同学们大家好呀,今天小编为大家分享开发者学院中课程“Spring Boot2.5使用Spring Data链接MySQL数据库”干货总结哦~Spring Boot 2.5.x开发实战可是Java中级工程师必备课程;
课程链接以及图谱地址小编已经为大家指路了,搭配学习效果更佳👇
课程名称:Spring Boot 2.5.x开发实战
课程地址:https://developer.aliyun.com/learning/course/71?spm=a2c6h.21254954.0.0.4e905907uoWZzr
图谱名称:Alibaba Java 技术图谱
图谱地址:https://developer.aliyun.com/graph/java?spm=a2c6h.21110250.J_5703890090.6.700e3c67EjOBeJ
Spring Boot2.5使用Spring Data链接MySQL数据
一、Spring Data简化MySQL数据访问
(一)Spring Data新特性
Spring在Spring boot之后再应用开发、微服务架构以及数据链接上都提供了专门的框架,大大简化开发工作,提升开发的效率。
Spring Data for MySQL有很多技术可以用,比如JDBC、JDBC Template、RM框架或者Hibernate My Business。
Spring Data会整合框架,简化整个框架的配置。这里面有个非常重要的Spring Data的子集叫JPA,实际就是加上了一个持久化的API,它其中有一块针对MySQL封装底层的Hibernate,也可以切换成My Business。
- Spring Data新特性
1. 快速数据访问框架,提供统一的编程模型
2. 强大的repository仓储和自定义对象映射ORM抽象
3. 从repository方法名称派生动态查询接口
4. 实现Domain域基类提供基本属性
5. 支持透明审计日志(创建,最后更改)
6. 可以自定义repository代码
7. 通过JavaConfig和自定义XML命名空间轻松实现 Spring集成
8. 与Spring MVC控制器的高级集成
9. 跨库持久性的实验支持
Spring Data针对各个数据源提供了统一的编程模型,其中有一个设计模式叫仓储模式,仓储模式在数据访问层又做了一层封装,主要针对各种不同的数据库提供统一的操作,有些默认接口直接生成不用再进行配置了。这个操作也可以结合其他的分层模型来进行整合。
(二)Spring Data架构
Spring Data主要是做各种不同的数据源的对接工作。有传统的关系型数据库也有非关系型数据库等等都可以和它进行集成。
Spring Data架构主要分成了关系型数据库和关系型数据库。JPA底层使用JDBC。
本次主要对关系型据库的一系列操作,后面对于访问Redis以及MongoDB后续课程也有对应的实战案例。
(三)Spring Data核心模块
1. Spring Data Commons - 支持每个Spring Data模块的Core Spring概念。2. Spring Data JDBC - 对JDBC的Spring Data存储库支持。3. Spring Data JDBC Ext - 支持标准JDBC的数据库特定扩展,包括对Oracle RAC快速连接故障转移的支持,AQ JMS支持以及对使用高级数据类型的支持。4. Spring Data JPA - JPA的Spring Data存储库支持。5. Spring Data KeyValue - 基于映射的存储库和SPI,可轻松构建用于键值存储的Spring Data模块。6. Spring Data LDAP - 对Spring LDAP的Spring Data存储库支持。7. Spring Data MongoDB - 基于Spring的对象文档支持和MongoDB的存储库。8. Spring Data Redis - 从Spring应用程序轻松配置和访问Redis。9. Spring Data REST - 将Spring Data存储库导出为超媒体驱动的RESTful资源。10. Spring Data Apache Cassandra - 轻松配置和访问Apache Cassandra或大规模,高可用性。
11. Spring Data Apache Geode - 轻松配置和访问Apache Geode。
12. Spring Data Apache Solr - 为面向搜索的Spring应用程序轻松配置和访问Apache Solr。13. Spring Data Pivotal GemFire - 轻松配置和访问Pivotal GemFire。
(四)Spring Boot2.5实战MySQL
1. Spring JDBC and JdbcTemplate
2. Spring Data JPA and Hibernate framework
3. Spring Data简化连接不同的数据库
4. 使用Spring Data JPA框架连接MySQL
5. 当然也可以使用原始的JDBC
6. 默认底层使用Hibernate框架
7. 支持Repository仓储模式
8. 引入最重要的2个包
9. spring-boot-starter-data-jpa
10. mysql-connector-java
JPA默认一个RM框架叫Hibernate框架。我们在对接的时候,需要大家去引几个包。作为Spring boot严格来说是有个傻瓜式编程,要简化配置。但是我们手动引入一个叫JDBC的包,然后再去配置数据库链接参数,数据库地址以及用户密码这些参数还是要自己设置。
对于初始化依赖,可以使用starter-data-jpa这样的一个依赖包。这里面还涉及到JdbcTemplate,这是Spring提供了一个非常重要的数据库操作的接口。
(五)Spring Data JPA框架
•Spring Data JPA简化数据访问层的开发工作•基于Spring和JPA构建存储库的完美支持•支持Querydsl谓词,从而支持类型安全的JPA查询•Domain类的透明审核•分页支持,动态查询执行,集成自定义数据访问代码的能力•在引导时验证@Query带注释的查询•支持基于XML的实体映射•引入@EnableJpaRepositories,基于JavaConfig的存储库配置。
在定义接口的时候,特殊的查询可能需要编写一些特殊的语句,下面来看一下具体的一个实现。
加入数据库访问链接,这里面有个spring data starter的JPA。加进来以后我们从数据库底层手动引一下MySQL-connector,里面devtools主要做自动化调试,方便进行程序的开发配置。改完代码以后不用重启,就会自动重新加载变化的数据配置文件。
Database platform在这里面指的是hibernate。Model在这里面指的是实体,和数据库直接对应。相比之前Spring data对应的数据源要配置一下。代码中有几个重要的参数分别是url、username以及password。
Spring Data Jpa是链接MySQL数据库重要的组件,在配置的时候要注意底层的MySQL connection。
配置MySQL参数
POM配置
仓储Repository泛型接口
第4课:
Java高级面试题
1. Spring Data JPA CRUD增刪改查 REST API
2. 如何基于Spring Boot+Spring Data实现登录注册?
3. Spring Data为什么只使用接口声明就可以访问数据库?
4. 默认Spring Data JPA 使用Hibernate,如何配置连接池?