如何在 Spring Boot 中 读写数据 (5)@Basic 指定类变量读取方法到数据库表字段的映射关系。对于没有任何特殊注解的getXxxx()方法,默认带有 @Basic 注解。...也就是说,除非特殊情况,否则所有的类变量都带有 @Basic 注解,这些变量都映射到指定的表字段中。 @Basic 注解有一个 fetch 属性用于表示读取策略。...策略有两种EAGER和LAZY,它们分别表示为主动读取与懒加载。默认为 EAGER。 (6)@Column 表示列的说明,如果字段名与列名相同,则可以省略。 @Column 注解拥有以下属性: ?...这四种关系注解都有 fetch 与 cascade 两种属性。 fetch 属性用于指定数据延迟加载策略: ?...CascadeType.ALL | 以上四种策略 无 | 默认值 因为这四种注解只能表示实体之间几对几的关系,指定与所操作实体相关联的数据库表中的列字段,就需要用到 @JoinColumn 注解。
前言 JPA是Java Persistence API的简称,中文名Java持久层API,是JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体[对象持久化]到数据库中。...JPA缺点:不适合关联关系复杂的项目。 正题 正常情况下使用@ManyToMany注解描述多对多关系时,JPA自动生成的表中是只包括两个对应实体的主键信息的。...有些时候呢,就会遇到需要在关联表中加入想要的其他字段来辅助完成需求。比如部门与部门人之间关系。...主体思路就是将@ManyToMany生成的关系表单独作为一个类,使用两个@ManyToOne来进行实现。...表生成结构 五、使用 通过关系表类来获取需要的辅助字段。
)其中的fetch有两个值,一个是FetchType.LAZY(懒加载),一个是FetchType.EAGER(饿汉式) 测试 使用前面讲过的Student和Teacher类 测试默认的情况(饿汉式的加载...=FetchType.LAZY) //设置wife的主键为Husband的外键,默认的对应表中的字段为wife_id @JoinColumn(name="wifeid") // 默认外键的名字为wife_id...@OneToOne都设置fetch属性的值为懒加载 一对多或者多对一 如果是@ManyToOne的方式,那么默认的就是EAGER方式进行查找。...多对多 多对多的关联查询默认使用的懒加载(LAZY) 如果想要设置饿汉式加载,可以使用@ManyToMany(fetch=FetchType.EAGER),这里就不在演示了 如果在双向外键关联中都要饿汉式加载...,那么可以在两个@ManyToMany注解中设置属性
fetch:配置是否采用延迟加载。 targetEntity:配置目标的实体类。映射多对多的时候不用写。...@JoinTable 作用:针对中间表的配置 属性: nam:配置中间表的名称 joinColumns:中间表的外键字段关联当前实体类所对应表的主键字段...对象导航查询的使用要求是:两个对象之间必须存在关联关系。...* fetch:配置关联对象的加载方式 * 值:EAGER 立即加载 不推荐使用立即加载 * LAZY 延迟加载 */...@OneToMany(mappedBy = "customer",cascade = CascadeType.ALL,fetch = FetchType.EAGER) private Set<LinkMan
,可以存放大的数据(文本和字节) @Transient不成为持久化字段及不跟数据库中的字段形成映射 @Basic(fetch=FetchType.LAZY) 是否把数据装载到内存中延迟初始化,第一次访问的时候在加载数据...表示一个多对一的映射,该注解标注的属性通常是数据库表的外键 optional:是否允许该字段为null,该属性应该根据数据库表的外键约束来确定,默认为true 可选 fetch:表示抓取策略,...默认为FetchType.EAGER cascade:表示默认的级联操作策略,可以指定为ALL,PERSIST,MERGE,REFRESH和REMOVE中的若干组合,默认为无级联操作 targetEntity....多对多关联上是两个一对多关联,但是在ManyToMany描述中,中间表是由ORM框架自动处理 可选 targetEntity:表示多对多关联的另一个实体类的全名,例如:package.Book.class... mappedBy:表示多对多关联的另一个实体类的对应集合属性名称 两个实体间相互关联的属性必须标记为@ManyToMany,并相互指定targetEntity属性, 需要注意的是,有且只有一个实体的
懒加载导致的N + 1问题 Hibernate的懒加载有个让人诟病的问题,就是所谓的N + 1问题:如果一个实体里存在一个懒加载的集合对象,在查询该实体时,会发出一条SQL。...如果这个实体比较复杂,存在多个懒加载的集合,集合对象又各自关联了其他的懒加载的集合,如果触发查询这些集合,就会发出大量的SQL去查询,对DB造成较大的负荷。...: cannot simultaneously fetch multiple bags,该异常由Hibernate引发,当一个实体中定义了两个及两个以上的非懒加载的集合时,即fetch = FetchType.EAGER...简单来说,Hibernate默认会用一条SQL直接把FetchType.EAGER的集合也一起left join进来,如果这些集合允许重复值,且存在两个及两个以上的这些集合,而集合又可能关联其他的对象。...有时候需要在pojo中定义一个常量字段,仅用于业务逻辑,且不希望该字段被映射到数据库中,也就是说这个字段的值不需要被持久化的数据库中。
例如:我们通过ID查询方式查出一个客户,可以调用Customer类中的getLinkMans()方法来获取该客户的所有联系人。对象导航查询的使用要求是:两个对象之间必须存在关联关系。...配置方式: /** * 在客户对象的@OneToMany注解中添加fetch属性 * FetchType.EAGER :立即加载 * FetchType.LAZY :延迟加载...*/ @OneToMany(mappedBy="customer",fetch=FetchType.EAGER) private Set linkMans = new HashSet...通过配置的方式来设定,只要查询从表实体,就把主表实体对象同时查出来 配置方式 /** * 在联系人对象的@ManyToOne注解中添加fetch属性 * FetchType.EAGER :...立即加载 * FetchType.LAZY :延迟加载 */ @ManyToOne(targetEntity=Customer.class,fetch=FetchType.EAGER)
2、关联的分类:关联可以分为一对一、一对多/多对一、多对多关联 关联是有方向的 关联的关键点都在外键上 如何建立一对多双向关联 以订单和订单项做案例 一个订单对多个订单项,多个订单项对一个订单 在订单实体类中需要添加两个属性...: Set orderItems initOrderItems = 0;//0代表懒加载 1代表立即加载 在订单项的实体类中需要添加一个属性:Order order 定义一对多的关系时需要采用接口方式...,: 1、hibernate配置了关联关系 2、当操作数据的时候,两个关联对象被hibernate管理起来, 3、两个对象之间必须建立关联关系 查询数据测试 @Override public...(fetch=FetchType.EAGER) //没有懒加载, @OneToMany(fetch=FetchType.LAZY) //使用懒加载, 由于不使用懒加载效率很低,所以我们默认都使用懒加载...(cascade = {CascadeType.MERGE,CascadeType.PERSIST}, fetch = FetchType.EAGER) @JoinTable(name = "user_role
FIELD Java @Annotations 对于一个类字段,有多种注解取决于该字段的类型和用途。例如,@Id注释必须在类属性之一中声明。存储在数据库中的每个实体对象都有一个主键。...@Size注释划定了被注释元素的边界。边界由两个属性 min 和 max 指定。.... // region OneToOne @OneToOne(fetch = FetchType.EAGER, cascade = CascadeType.ALL, targetEntity...另一个表定义其他两个相关表之间的桥接表。...它可以用于字段、方法或构造函数参数。它也可以用在类中,在某些情况下,指定的规则适用于类的所有属性。
配置当前对象在中间表中的外键(第一个参数是中间表的字段,第二个参数是本表对应的字段) joinColumns = {@JoinColumn(name = "uid", referencedColumnName...= FetchType.EAGER) @JsonIgnore private Set users = new HashSet(); @Override...级联的属性: 1. CascadeType.PERSIST 级联持久化(保存)操作:持久保存拥有方实体时,也会持久保存该实体的所有相关数据。这个属性就是造成上面问题的关键。...CascadeType.REMOVE 级联删除操作:删除当前实体时,与它有映射关系的实体也会跟着被删除。 3....CascadeType.DETACH 级联脱管/游离操作:如果你要删除一个实体,但是它有外键无法删除,你就需要这个级联权限了。它会撤销所有相关的外键关联。 4.
第二步:在数据库中实现两张表的关系 第三步:在实体类中描述出两个实体的关系 第四步:配置出实体类和数据库表的关系映射(重点) 第4章 JPA 中的一对多 4.1 示例分析 我们采用的示例为客户和联系人...配置的方式: /** * 在客户对象的@OneToMany 注解中添加 fetch 属性 * FetchType.EAGER :立即加载 * FetchType.LAZY :延迟加载 */...配置的方式: /** * 在联系人对象的@ManyToOne 注解中添加 fetch 属性 * FetchType.EAGER :立即加载 * FetchType.LAZY :延迟加载 */...要求: 两个实体必须有关联关系,才能使用此种查询方式。...它的写法是: 把查询的表名换成实体类名称,把表中的字段名换成实体类的属性名称。 注意: 此处我们必须明确,实体类属性名称指的是 get/set 方法后面的部分,且首字母改小写。
目前有两种注释方案可以确定对象与表格之间的对应关系:一种是注释实体类的属性字段(字段级别注释),成为字段访问方式(field access mode);另一种是注释实体类的属性访问方法(方法级别注释),...fetch: 表示抓取策略 , 默认为 FetchType.EAGER cascade: 表示默认的级联操作策略 , 可以指定为 ALL,PERSIST,MERGE,REFRESH 和 REMOVE 中的若干组合...的关系 , 则实体 User 被删除时 , 其关联的实体 Order 也应该被全部删除 2.3.4 @OneToOne(可选) @OneToOne(fetch=FetchType,cascade=...此时更新的话,由于两个对象的OID是一样的,但是却发生了修改,使用update的话,两个对象是不能合并的,只能用merge()方法将其更新,即将两个对象合并。...延迟加载的特点:真正用到该对象的时候才开始查询改对象的属性。 如果是立即加载,需要在Customer的set集合的注解中加入下边的语句:fetch=FetchType.EAGER,如下图: ?
由于实体类可以继承,同时扩展其字段。如果在字段级别定义了 JPA 注解的话,就不能通过覆写它的对应 getter 方法来达到覆写它的目的。...在同一个实体层次结构中必须保持同一种使用注解的方式,即一个实体及其子类中必须保证注解方式的一致性。但可以使用注解 @Access 来指明这一个特定的子类使用了另一种不同的注解方式来注解其字段和方法。...Embedded:在这种关系中,其它实体是和其父实体存储在同一个表中(即,每一个表都有两个实体)。...(fetch = FetchType.EAGER) @OneToOne(fetch = FetchType.LAZY) FetchType.EAGER 是默认值,它表示每次加载一个 Person 时也要同时加载...然后,在每个需要建模 Period 时间的实体内,都可以重用 Period 类,这样也就避免了在每个实体内拷贝这两个类字段 startDate 和 endDate。
),需要实现AuditorAware接口来返回你需要插入的值 @CreationTimestamp 表示该字段为创建时间时间字段 @UpdateTimestamp 表示该字段为修改时间时间字段 实体类相关注解...@Table 标注的常用选项是 name,用于指明数据库的表名 @Table标注还有一个两个选项 catalog 和 schema 用于设置表所属的数据库目录或模式,通常为数据库名。...@Basic @Basic 表示一个简单的属性到数据库表的字段的映射,对于没有任何标注的 getXxxx() 方法,默认即为 @Basic fetch: 表示该属性的读取策略,有 EAGER 和 LAZY...两种,分别表示主支抓取和延迟加载,默认为 EAGER....entity class的所有id field在id class都要定义,且类型一样。 @MapKey 在一对多,多对多关系中,我们可以用Map来保存集合对象。
,一般用于jpa,这两个注解一块使用,但是如果表名和实体类名相同的话,@Table可以省略。...注意: 标注为@MappedSuperClass的类将不是一个完整的实体类,它将不会映射到数据库表,但是它的属性都映射到其子类的数据库字段中。...如果一个属性并非数据库表的字段映射,就务必将其标注为@Transient,否则,ORM框架默认将其注解为@Basic。 7、@Basic @Basic 是实体类与数据库字段映射时最简单的类型。...@basic注解有两个属性: fetch用来指定属性的加载机制 有两个选项:EAGER(即时加载,默认值)和LAZY(懒加载),即时加载意味着当实例化对象的时候必须加载该属性值,懒加载是指当实例化对象时不加载该对象...8、@JsonIgnore 在实体类向前台返回数据时用来忽略不想传递给前台的属性或接口。 Bean实体中会有某些运维字段,返回信息给前台的时候,不希望将对应值一并返回。
strategy ): fetch:抓取策略,延时加载与立即加载,optional:指定在生成数据库结构时字段是否允许为 null....映射实体Bean的关联关系 一对一 使用 @OneToOne 注解可以建立实体Bean之间的一对一关系。一对一关系有3种情况。 • 关联的实体都共享同样的主键。...上例为 passport_id, 因为Customer 中关联属性为 passport, Passport 的主键为 id. • 通过关联表来保存两个实体之间的关联关系。...关键字段默认值和一对一关联的情况相似。...通常使用惰性加载的方式, @Basic(fetch=FetchType.LAZY) @SecondaryTable @javax.persistence.SecondaryTable 将一个实体映射到多个数据库表中
同时,创建了实体就能够自动帮我们创建数据库表了,修改了实体字段也能够将数据表一起修改。顿时就觉得很好用了。...二、JPQL基础 原来JPQL是JPA的一种查询语言,之前我是认为它和HQL是一样的。其实是两个概念。不过它们用起来还真是差不多。 无非就是:JPA对应JPQL,而Hibernate对应HQL而已。...属性表示默认关联的实体类型,默认为当前标注的实体类。...3,fetch属性是该实体的加载方式,默认为即时加载EAGER 4,optional属性表示关联的该实体是否能够存在null值,默认为ture,如果设置为false,则该实体不能为null, 5,...2,**如果不设置name,默认name = 关联表的名称+”-“+关联表主键的字段名,在上面实例3,中,默认为“address_id” ** 默认情况下,关联实体的主键一般是用来做外键的,但如果此时不想用主键作为外键
JPA的出现有两个原因: 简化现有Java EE和Java SE应用的对象持久化的开发工作; Sun希望整合对ORM技术,实现持久化领域的统一。...JPA提供的技术: ORM映射元数据:JPA支持XML和JDK 5.0注解两种元数据的形式,元数据描述对象和表之间的映射关系,框架据此将实体对象持久化到数据库表中; JPA 的API:定义规范,以操作实体对象...remove,删除受控实体 merge,将游离实体转变为Managed状态,数据存入数据库。 如果使用了事务管理,则事务的commit/rollback也会改变实体的状态。...JPA提供了以下几种ID生成策略 GeneratorType.AUTO ,由JPA自动生成 GenerationType.IDENTITY,使用数据库的自增长字段,需要数据库的支持(如SQL Server...关联关系还可以定制延迟加载和级联操作的行为。 通过设置fetch=FetchType.LAZY 或 fetch=FetchType.EAGER来决定关联对象是延迟加载或立即加载。
关系型数据库 关系数据库,是建立在关系模型基础上的数据库,借助于集合代数等数学概念和方法来处理数据库中的数据。现实世界中的各种实体以及实体之间的各种联系均用关系模型来表示。...一对一 如果我们只是单纯的在两个实体类中分别加上@OneToOne注解,会发现两张表都分别引入了对方的主键作为外键。明显的数据冗余,毕竟关系不用双方存储。...一对多关系处理 创建两个实体对象,分别对应一与多的一方。...多对多 正常建立两个多对多关系实体 1.多对多实体一 package com.example.demo.entity.manytomany; import java.util.List; import...FetchType.EAGER:急加载,加载一个实体时,定义急加载的属性会立即从数据库中加载。 结语 本文属于基础篇。觉得不错也可以点亮下方小星星。
,其中有一个name属性指定当前实体类映射的表的名称 name: 可选属性 ,指定对应表的名称,如果没有指定name属性,那么创建表的名称和类名一样 @Table : 在实体类的上方使用,和Entity...与非主键相关的注解 @Version - 可以在实体bean中使用@Version注解,通过这种方式可添加对乐观锁定的支持 @Basic - 用于声明属性的存取策略: @Basic(fetch=FetchType.EAGER...) 即时获取(默认的存取策略) @Basic(fetch=FetchType.LAZY) 延迟获取 @Temporal 这个使用来设置数据库表中显示的日期的精度,因为java中的Date属性可以对应着数据库中的三种类型...-- 直接指定这个Teacher实体类的全类名即可,即是完成了映射 --> @JoinColumn 我们知道外键的生成的字段的名称是默认的...name 设置第三张表的名称 joinColumns 设置的是当前实体类对应的表在第三张表的外键的字段名称 inverseJoinColumns 设置的是另外一个实体类对应的表在第三张表的外键的字段名称
领取专属 10元无门槛券
手把手带您无忧上云