开发者学堂课程【Spring Boot 2.5.x 开发实战:Spring Boot 实战- Spring Data 数据访问 MySQL】学习笔记,与课程紧密联系,让用户快速学习知识。
课程地址:https://developer.aliyun.com/learning/course/853/detail/14069
Spring Boot 实战- 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。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 Key Value - 基于映射的存储库和 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 的存储库配置。
自定义了一个 Querydsl 语言,Domain 针对数据库操作提供了查询的领域语言,该语法类 SQL 。
在定义接口的时候,特殊的查询可能需要编写一些特殊的语句,下面来看一下具体的一个实现。
对项目进行改造,改造要加入新的引用,除了 Web 引用,加入数据库访问链接,这里面有个 spring data starter 的JPA。加进来以后我们从数据库底层手动引一下 MySQL-connector链接驱动,里面 devtools 主要做自动化调试,方便进行程序的开发配置。改完代码以后不用重启,就会自动重新加载变化的数据配置文件。
代码的实现,需要配 Spring Data 对应的数据源,用户名密码,数据库,在本地要安装一个 MySQL 的数据库,我们这里先建立一个叫阿里巴巴,然后直接会有一个表,这个表有很简单的几个字段,用户名密码,姓名,年龄,城市,地址,前面是 ID 就三条数据,主要用来测试。
我们主要是看代码,代码链数据库需要几个重要的参数 url ,username 和 password。如果有多语言设置的,稍微注意编码以及 uesSSL 的警告。驱动要指定新版本的这个驱动的名字,老版本的可能会有点变化。
Database-platform 这里面就是直接看一下。然后后面的话就是简单的分成了控制器比如增删改查的控制器和数据库直接对应。Model 的话没做详细的,正常的话,model 应该和实体不一样。Query 语言这个语法和 SQL 是类似语法,可以通过注解指定查询语句,可以根据用户名,用户密码以及 id 进行查询,有时候这些在基础的增删改查中没有,默认创建这些方法就比较方便。在仓储模式中直接指定了主件是什么类型,一个用户一个 user 的一个类型。控制器使用仓储的接口定义了一个仓储的变量,用户的一个变量可以用来查询所有的用户,这接口就是属于获得所有的用户或者是用户,返回客户端,不需要做复杂的配置。
注意,仓储层的仓储对象是个接口,比如一个接口是自动注入使用的框架叫依赖注入,依赖注入底层,使用了反射包括对象创建以及依赖注入整个一系列过程。
代码很清晰,整个一个 Spring 平台容器帮助我们做了很多工作,注意,严格来说模型可以再拆分,可以把实体和应用模型拆开,业务逻辑层也可以删掉,因为我们就是简单验证如何通过 Spring Boot 链接数据库。
数据库中含有增删改查,我们只需做查询,演示一下,可以看到 delete 删除,删除所有,findAll 查询所有,getUserById, getUserByName 等,除了自定义的接口的方法属于自定义扩展方法,实际已经包括增删改查。增删改查基本都实现了,只需做一些特殊的自定义的一些接口的一些配置,配置开发工作即可,Spring Data 能够简化底层的一个开发工作。
可以看到加了 Spring Data 依 赖以后,除了 Spring Boot 正常的一个依赖,实际还有 HiKariCP,这是属于这个链接池,链接池这样的一个很重要的一个组件,性能比较高,以及 starter-jdbc。注意,hibernate 用的是5.4.23版本。Spring Data 实际是做了再次的分装,接口更自动化,增删改查都不用写。
Spring Data JPA 是链接 MySQL 数据库重要的组件,在配置的时候要注意底层的 MySQL connection。
运行测试一下我们的项目,正常启动没有错误,打开浏览器,搜索localhost:8081/ Home/getAll 就能看到结果(三条测试数据)。
注意 Spring Data JPA 是链接 MySQL 数据库非常重要的主件,配置时注意引入底层的 MySQL Connection 以及 JPA 主件。
Java高级面试题
1. Spring Data JPA CRUD 增刪改查 REST API
2. 如何基于 Spring Boot+Spring Data 实现登录注册?
3. Spring Data 为什么只使用接口声明就可以访问数据库?
4. 默认 Spring Data JPA 使用 Hibernate,如何配置连接池?