全自动orm框架SpringData Jpa 简单使用

目录

介绍

整合springboot

简单使用

基本操作

查询数据

新增

[​编辑 删除](#编辑 删除)

[​编辑 分页查询](#编辑 分页查询)

自定义方法查询

自定义sql查询

一对一映射

一对多映射

​编辑


介绍

Spring data JPA是Spring在ORM框架,以及JPA规范的基础上,封装的一套JPA应用框架,并提供了一整套的数据访问层解决方案。

Spring data JPA的功能非常的强大,这里我们先跳过环境搭建这一步,来一睹Spring data JPA的"芳容"。

Spring data JPA提供给用户使用的,主要有以下几个接口:

Repository:仅仅是一个标识,表明任何继承它的均为仓库接口类,方便Spring自动扫描识别

CrudRepository:继承Repository,实现了一组CRUD相关的方法

PagingAndSortingRepository:继承CrudRepository,实现了一组分页排序相关的方法

JpaRepository:继承PagingAndSortingRepository,实现一组JPA规范相关的方法

JpaSpecificationExecutor:比较特殊,不属于Repository体系,实现一组JPA Criteria查询相关的方法。

整合springboot

简单使用

引入依赖

java 复制代码
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

yml配置

jpa可以直接对实体类进行配置,并在yml中开启建表的自动配置,启动项目时就会自动帮我们创建实体类对应的数据库表,这样就不需要手动创建表

创建实体类

此时数据库表中并没有tb_student表

启动项目测试

查看数据库

基本操作

查询数据

插入测试数据

新建student持久层

记得将ymal配置中的create调整成update,否则每次启动测试都会删除创建表操作

新增

删除

分页查询

插入测试数据

自定义方法查询

在持久层中直接定义,书写findAll后有自动提示,拼接条件

自定义sql查询

查询

修改

如果想要完全使用原生sql,属性值和实体类也不想用,需要添加nativeQuery=true属性

注意比较实体和纯原生sql区别

一对一映射

新建部门实体

对应表

设置一对一对应

一对多映射

创建一个作品表,一个人可以对应多个作品

Student实体维护一对多关系

测试插入学生

查看插入结果

一个学生李白对应多个作品

观察sql是一个左外关联

相关推荐
EnigmaCoder2 分钟前
Java多线程:核心技术与实战指南
java·开发语言
攀小黑6 分钟前
阿里云 使用TST Token发送模板短信
java·阿里云
麦兜*11 分钟前
Spring Boot秒级冷启动方案:阿里云FC落地实战(含成本对比)
java·spring boot·后端·spring·spring cloud·系统架构·maven
自由鬼38 分钟前
正向代理服务器Squid:功能、架构、部署与应用深度解析
java·运维·服务器·程序人生·安全·架构·代理
fouryears_234171 小时前
深入拆解Spring核心思想之一:IoC
java·后端·spring
魂兮归乡1 小时前
B2、进度汇报(— 25/06/16)
经验分享·spring boot·ai·vue·团队开发·课程设计·web app
codervibe2 小时前
使用 Spring Boot + JWT 实现多角色登录认证(附完整流程图)
java·后端
坚持学习永不言弃2 小时前
Ehcache、Caffeine、Memcached和Redis缓存
java
阿劲2 小时前
从业务卡顿到数据库连接池耗尽:Spring Boot项目HikariCP超时问题实战排查
java·后端·面试
Q_Q5110082852 小时前
python的保险业务管理与数据分析系统
开发语言·spring boot·python·django·flask·node.js·php