首页
学习
活动
专区
圈层
工具
发布

Spring的学习笔记(十七)——SpringDataJpa动态查询和复杂的多表操作

Specifications动态查询 有时我们在查询某个实体的时候,给定的条件是不固定的,这时就需要动态构建相应的查询语句,在Spring Data JPA中可以通过JpaSpecificationExecutor...包含关系:可以通过实体类中的包含关系描述表关系 继承关系 分析步骤 1.明确表关系 2.确定表关系(描述 外键|中间表) 3.编写实体类,再实体类中描述表关系...属性: name:指定外键字段的名称 referencedColumnName:指定引用主表的主键字段名称 unique:是否唯一。...从表:联系人表 * 再从表上添加外键 3.编写实体类,再实体类中描述表关系(包含关系) 客户:再客户的实体类中包含一个联系人的集合...属性: name:指定外键字段的名称 referencedColumnName:指定引用主表的主键字段名称 unique:是否唯一。

5.4K10

Spring全家桶之SpringData——Spring Data JPA

Spring Data JPA 一、介绍 常用注解 实体类中 测试类中 相关术语 二、实战应用 :搭建Spring Data JPA项目 介绍 步骤 1....导入jar 两个核心jar 加上3个sl4j的jar 2. 在配置文件中开启Spring Data JPA的命名空间以及它的约束 3. 在配置文件中添加Spring Data JPA的配置 4....创建用户实体 创建角色实体 测试代码 多对多的关联操作 创建菜单实体 创建角色实体 创建接口 测试代码 一、介绍 Spring Data JPA:Spring Data JPA 是spring data...在配置文件中添加Spring Data JPA的配置 Spring Data JPA 的配置 --> 的关联操作 需求:从角色到用户的一对多的关联关系 角色:一方 用户:多方(添加外键) 创建用户实体 需要在添加外键的那一开启级联操作 ,防止数据插入时出现异常 @ManyToOne(cascade

4.5K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Spring Data JPA 的应用

    一、Spring Data JPA 概述 1、什么是 Spring Data JPA Spring Data JPA 是应用于Dao层的一个框架,简化数据库开发的,作用和MyBatis框架一样,但是在使用方式和底层机制是有所不同的...使用了Spring Data JPA,我们Dao层中只需要写接口,不需要写实现类,就自动具有 了增删改查、分⻚查询等方法。 使用Spring Data JPA 很多场景下不需要我们自己写sql语句。...2、Spring Data 家族 二、Spring Data JPA,JPA规范和Hibernate之间的关系 Spring Data JPA 是 Spring 提供的一个封装了JPA 操作的框架,而...Spring Data JPA 是 Spring 提供的一套对 JPA 操作更加高级的封装,是在 JPA 规范下的专⻔用来进行数 据持久化的解决方案。...Data JPA 开发步骤梳理 构建工程 创建工程导入依赖(Java框架于我们而言就是一堆jar) 配置 Spring 的配置文件(配置指定框架执行的细节) 编写实体类 Resume,使用 JPA 注解配置映射关系

    20210

    Spring Data JPA 就是这么简单

    当我们项目中使用 spring data jpa 的时候,你会发现有时候没有 sql 语句,其实框架的底层已经帮我们实现了,我们只需要遵守规范使用就可以了,下面会详细谈到 spring data jpa...spring data jpa常用的 jpa 的配置 下面所有演示的代码均来自我个人 github 的 spring-data-jpa 仓库,仓库地址:https://github.com/kickcodeman...,运行程序我们会发现在 stu 表中新增了一个 class_room_id 的外键。...当一个实体类使用了 mappedBy 属性,表示该类放弃主键的维护,该类生成的表中不存放和它关联类的外键。...,把学生也保存到数据库当中,但是因为教室类不进行外键的维护,虽然学生类保存成功,但是是失败的,因为它们之间的关系并没有建立起来,查看学生表的新增数据我们会发现新增的学生并没有教室的外键存在。

    8.2K50

    快速学习-Specifications动态查询

    第1章 Specifications动态查询 有时我们在查询某个实体的时候,给定的条件是不固定的,这时就需要动态构建相应的查询语句,在Spring Data JPA中可以通过JpaSpecificationExecutor...Specification接口中只定义了如下一个方法: //构造查询条件 /** * root :Root接口,代表查询的根对象,可以通过root获取实体中的属性 * query...Data Jpa 内部的page bean * 此重载的findAll方法为分页方法需要两个参数 * 第一个参数:查询条件Specification * 第二个参数:...分页参数 */ Page page = customerDao.findAll(spec,pageable); } 对于Spring Data JPA中的分页查询,...是其内部自动实现的封装过程,返回的是一个Spring Data JPA提供的pageBean对象。

    1.8K10

    Spring整合Hibernate、Hibernate JPA、Spring Data JPA、Spring Data Redis

    3、Spring Data JPA:Spring Data JPA 是 spring data 项目下的一个模块,提供了一套基于 JPA 标准操作数据库的简化方案,底层默认的是依赖 Hibernate...3.1)、Spring Data JPA 的技术特点:我们只需要定义接口并集成 Spring Data JPA 中所提供的接 口就可以了,不需要编写接口实现类。...; 5 6 /** 7 * 使用Spring Data JPA 8 * 9 * JpaRepository泛型参数一是实体类的名称,参数二是实体类的主键类型...相同的,外键和主键相同的 22 // 表示外键和主键相同的,做在角色表里面角色和那个用户之间的描述。...Spring Data JPA中有四种Cascade 类型: 1)、PERSIST:持久保存拥有的实体,也会持久保存该实体的属于相关数据。

    6.6K30

    SpringDataJPA 系列之快速入门

    1.1 简介 1.1.1 概述   Spring Data JPA 是 Spring 基于 ORM 框架、JPA 规范的基础上封装的一套 JPA 应用框架,可使开发者用极简的代码即可实现对数据库的访问和操作...它提供了包括增删改查等在内的常用功能,且易于扩展!学习并使用 Spring Data JPA 可以极大提高开发效率!...Spring Data JPA 让我们解脱了 DAO 层的操作,基本上所有 CRUD 都可以依赖于它来实现,在实际的工作工程中,推荐使用 Spring Data JPA + ORM(如:hibernate...SpringDataJPA是 Spring 提供的一套对 JPA 操作更加高级的封装,是在 JPA 规范下的专门用来进行数据持久化的解决方案。 ?...> query, CriteriaBuilder cb); 参数说明:  ♞ root:Root 接口,代表查询的根对象,可以通过 root 获取实体中的属性;  ♞ query:代表一个顶层查询对象

    2K30

    Spring-data-jpa(spring数据持久层解决规范)详解

    大致整理一个提纲:   1、Spring-data-jpa的基本介绍;   2、和Spring整合;   3、基本的使用方式;   4、复杂查询,包括多表关联,分页,排序等; 现在开始:   1、Spring-data-jpa...这里介绍Spring-data-jpa,表示与jpa的整合。   ...下面我们通过一个完整的项目来基本使用spring-data-jpa,然后我们在介绍他的高级用法。   a.数据库建表:user,主键自增 ?   b.对应实体:User ?...手动配置锁:   spring-data-jpa支持注解方式的sql,比如:@Query(xxx),另外,关于锁的问题,在实体中的某个字段配置@Version是乐观锁,有时候为了使用一个悲观锁,或者手动配置一个乐观锁...一对多、多对多查询(查询条件在关联对象中时):   1、在JPA中,一个实体中如果存在多个关联对象,那么不能同时eager获取,只能有一个是eager获取,其他只能lazy;在Hibernate当中有几种独有的解决方法

    3.5K20

    【原创】纯干货,Spring-data-jpa详解,全方位介绍。

    这里不讲解JPA和Spring-data-jpa单独使用,所有的内容都是在和Spring整合的环境中实现。如果需要了解该框架的入门,百度一下,很多入门的介绍。...这里介绍Spring-data-jpa,表示与jpa的整合。   ...在这个时候,Spring-data-jpa的威力就体现出来了,ORM提供的能力他都提供,ORM框架没有提供的业务逻辑功能Spring-data-jpa也提供,全方位的解决用户的需求。...手动配置锁:   spring-data-jpa支持注解方式的sql,比如:@Query(xxx),另外,关于锁的问题,在实体中的某个字段配置@Version是乐观锁,有时候为了使用一个悲观锁,或者手动配置一个乐观锁...一对多、多对多查询(查询条件在关联对象中时):   1、在JPA中,一个实体中如果存在多个关联对象,那么不能同时eager获取,只能有一个是eager获取,其他只能lazy;在Hibernate当中有几种独有的解决方法

    2.4K10

    Spring-data-JPA详细介绍,增删改查实现「建议收藏」

    这里不讲解JPA和Spring-data-jpa单独使用,所有的内容都是在和Spring整合的环境中实现。如果需要了解该框架的入门,百度一下,很多入门的介绍。...这里介绍Spring-data-jpa,表示与jpa的整合。   ...在这个时候,Spring-data-jpa的威力就体现出来了,ORM提供的能力他都提供,ORM框架没有提供的业务逻辑功能Spring-data-jpa也提供,全方位的解决用户的需求。...手动配置锁:   spring-data-jpa支持注解方式的sql,比如:@Query(xxx),另外,关于锁的问题,在实体中的某个字段配置@Version是乐观锁,有时候为了使用一个悲观锁,或者手动配置一个乐观锁...一对多、多对多查询(查询条件在关联对象中时):   1、在JPA中,一个实体中如果存在多个关联对象,那么不能同时eager获取,只能有一个是eager获取,其他只能lazy;在Hibernate当中有几种独有的解决方法

    4.8K30

    Spring Boot第八章-Spring Data JPA(续)

    目录 1.jpa自定义sql查询 2.jpa更新 3.jpa删除 4.一些常用注解的理解 5.自定义查询简单实例: 6.JPA 关联表自定义动态查询 ---- 上一个博客介绍了Spring Data JPA...如果缺省@Table注释,系统默认采用类名作为映射表的表名。实体Bean的每个实例代表数据表中的一行数据,行中的一列对应实例中的一个属性。...@Id注释指定表的主键,它可以有多种生成方式: 1)TABLE:容器指定用底层的数据表确保唯一; 2)SEQUENCE:使用数据库德SEQUENCE列莱保证唯一(Oracle数据库通过序列来生成唯一ID...); 3)IDENTITY:使用数据库的IDENTITY列莱保证唯一; 4)AUTO:由容器挑选一个合适的方式来保证唯一; 5)NONE:容器不负责主键的生成,由程序来完成。...; import org.springframework.data.domain.Sort; import org.springframework.data.jpa.domain.Specification

    1.8K20

    Spring Boot整合Spring Data JPA

    1、Spring Data是Spring提供的帮助操作数据的框架,Spring Data中的一个模块叫做Spring Data JPA,Spring Data JPA只是Spring Data框架下的一个基于...JPA标准操作数据的模块,Spring Data JPA底层默认的使用的是Hibernate来做的JPA实现。...外键和主键相同的 21 // 表示外键和主键相同的,做在角色表里面角色和那个用户之间的描述。...= "roles") //表示一对多的关系,mappedBy表示向Set集合放Users,放的是当前roles相同的,外键和主键相同的 22 // 表示外键和主键相同的,做在角色表里面角色和那个用户之间的描述...,表示菜单和角色是多对多的关系 27 // joinColumns当前表中的主键所关联的中间中的外键字段. 28 // inverseJoinColumns那一侧的中间的外键的名称叫什么

    4.4K30

    Spring Boot 之 Spring Data JPA 三(Specifications)一、首先建立一个Spring Boot 工程二、编写一个实体类来记录数据三、通过接口实现Specifica

    一、首先建立一个Spring Boot 工程 我们使用的IDE是InteliJ IDEA,开发语言是Kotlin, ?...项目信息 Spring 的工程特性选择了JPA、Rest Repository和一种数据库支持(这里是MySql) ?...项目工程特性 新建项目没有什么可说的,接下来我们正式进入编码: 二、编写一个实体类来记录数据 我们使用一个Record实体来保存数据,包含了名称和值,代码如下: package cn.techcave.demo.jpa3...org.springframework.data.jpa.repository.JpaRepository import org.springframework.data.jpa.repository.JpaSpecificationExecutor...import org.springframework.data.jpa.domain.Specifications.where import javax.persistence.criteria.CriteriaQuery

    1.9K50

    高级框架-springDate-JPA 第二天【悟空教程】

    在数据库中建立一对多的关系,需要使用数据库的外键约束。 什么是外键? 指的是从表中有一列,取值参照主表的主键,这一列就是外键。 一对多数据库关系的建立,如下图所示 ?...属性: name:指定外键字段的名称 referencedColumnName:指定引用主表的主键字段名称 unique:是否唯一。默认值不唯一 nullable:是否允许为空。...:中间表的外键字段关联对方表的主键字段 5.4.3 @JoinColumn 作用: 用于定义主键字段和外键字段的对应关系。...属性: name:指定外键字段的名称 referencedColumnName:指定引用主表的主键字段名称 unique:是否唯一。默认值不唯一 nullable:是否允许为空。...CriteriaQuery cq = cb.createQuery(Customer.class); //6.获取实体类对象的封装对象,有此对象之后,所有实体类都可以看成此类型

    3.2K10

    flea-db使用之JPA封装介绍

    获取FleaJPAQuery实例,并初始化内部成员变量EntityManager entityManager :JPA 中用于增删改查的持久化接口Class sourceClazz : 实体类类对象Class...新版本已废弃(单例模式,本身没有问题,但是由于获取之后 Flea JPA 查询对象还要使用,这在有点并发的环境下就存在问题了;后面我会单独写一篇博文讲解基于对象池的多例模式,既保证并发下各个线程获取的...该类实现上述抽象 Flea JPA DAO 层接口,同样有类型T,由子类指定其操作的实体类。...,由子类实现(可参考下面的持久化单元 DAO 层实现)getEntityManager() :获取实体管理器getEntityManager(T entity) :获取实体管理器【entity 实体类对象实例...】getEntityManager(T entity, boolean flag) :获取实体管理器【entity 实体类对象实例,flag 获取实体管理器标识【true:getFleaNextValue

    1.1K21
    领券