Spring Boot 实战- Spring Data 数据访问 MySQL|学习笔记

简介: 快速学习 Spring Boot 实战- Spring Data 数据访问 MySQL。

开发者学堂课程【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 BusinessMy 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 。

在定义接口的时候,特殊的查询可能需要编写一些特殊的语句,下面来看一下具体的一个实现。

image.png

对项目进行改造,改造要加入新的引用,除了 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 就能看到结果(三条测试数据)

image.png

image.png

注意 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,如何配置连接池?

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
2月前
|
监控 Cloud Native Java
Spring Boot 3.x 微服务架构实战指南
🌟蒋星熠Jaxonic,技术宇宙中的星际旅人。深耕Spring Boot 3.x与微服务架构,探索云原生、性能优化与高可用系统设计。以代码为笔,在二进制星河中谱写极客诗篇。关注我,共赴技术星辰大海!(238字)
Spring Boot 3.x 微服务架构实战指南
|
2月前
|
NoSQL Java 数据库连接
《深入理解Spring》Spring Data——数据访问的统一抽象与极致简化
Spring Data通过Repository抽象和方法名派生查询,简化数据访问层开发,告别冗余CRUD代码。支持JPA、MongoDB、Redis等多种存储,统一编程模型,提升开发效率与架构灵活性,是Java开发者必备利器。(238字)
|
2月前
|
XML Java 测试技术
《深入理解Spring》:IoC容器核心原理与实战
Spring IoC通过控制反转与依赖注入实现对象间的解耦,由容器统一管理Bean的生命周期与依赖关系。支持XML、注解和Java配置三种方式,结合作用域、条件化配置与循环依赖处理等机制,提升应用的可维护性与可测试性,是现代Java开发的核心基石。
|
2月前
|
存储 Java 关系型数据库
Spring Boot中Spring Data JPA的常用注解
Spring Data JPA通过注解简化数据库操作,实现实体与表的映射。常用注解包括:`@Entity`、`@Table`定义表结构;`@Id`、`@GeneratedValue`配置主键策略;`@Column`、`@Transient`控制字段映射;`@OneToOne`、`@OneToMany`等处理关联关系;`@Enumerated`、`@NamedQuery`支持枚举与命名查询。合理使用可提升开发效率与代码可维护性。(238字)
337 1
|
3月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
165 3
|
3月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
3月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
804 152
|
4月前
|
存储 运维 关系型数据库
从MySQL到云数据库,数据库迁移真的有必要吗?
本文探讨了企业在业务增长背景下,是否应从 MySQL 迁移至云数据库的决策问题。分析了 MySQL 的优势与瓶颈,对比了云数据库在存储计算分离、自动化运维、多负载支持等方面的优势,并提出判断迁移必要性的五个关键问题及实施路径,帮助企业理性决策并落地迁移方案。
|
3月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。