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

JPA 注解学习

最近学习hibernate注解形式配置POJO类,将注解的解析记下来,以备以后使用。 例1....; } public void setId(Long id) { this.id = id; } } Hibernate 可以对类的属性或者方法进行注解。...映射实体Bean的关联关系 一对一 使用 @OneToOne 注解可以建立实体Bean之间的一对一关系。一对一关系有3种情况。 • 关联的实体都共享同样的主键。...列名为:主题的关联属性名 + 下划线 + 被关联端的主键列名。本例中为company_id,因为关联的属性是company, Company的主键为 id....默认值: 关联表名:主表表名 + 下划线 + 从表表名;关联表到主表的外键:主表表名 + 下划线 + 主表中主键列名;关联表到从表的外键名:主表中用于关联的属性名+ 下划线 + 从表的主键列名。

3.8K10

Hibernate基于主键映射的一对一关联关系

在Hibernate中,一对一关联关系的映射可以使用主键映射的方式来实现。一、什么是一对一关联关系?...这种方式的优点是: 删除或更新数据库时不需要维护外键关系,因为在Hibernate中一对一关联关系使用同一个主键。 查询速度更快,因为查询操作只需要执行单个表的查询。...三、实现方式我们将通过一个简单的实例来演示如何在Hibernate中使用主键映射来实现一对一关系映射。...@OneToOne注解的mappedBy属性表示当前实体类中关联属性的名称与UserProfile实体类中的user属性相对应。...@OneToOne注解的fetch属性指定了默认的加载策略。我们还在@JoinColumn注解中指定了外键对应的字段名为“user_id”。

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

    Hibernate框架学习之注解配置关系映射

    这就是一个典型的单向的一对一的关联关系,所谓的一对一其实就是指,主表中的一条记录唯一的对应于从表中的一条记录。但具体到我们的实体类中又该如何来写呢?...而userinfo实体类定义了一个UserCode 类型的属性,当我们使用hibernate进行插入或者返回数据时候,usercode表中对应的记录则会被装在在这个属性中,当然,我们也通过它配置外键关联关系...@OneToOne注解指定这是一个一对一的关联关系,targetEntity 指定了被关联的实体类类型。...,hibernate首先会为我们插入四条userinfo记录到userinfo表中(其中的外键字段为空),然后插入一条记录到usersex表中,在这之后,hibernate将根据set集合中的元素依次执行这么一条...= "userCode") private UserInfo userInfo; //省略getter,setter方法 } 映射双向一对一关系的时候,需要在两端都使用@OneToOne

    2.8K90

    Hibernate关联关系

    Hibernate关联关系 1.1. 一对一 1.1.1. 背景 1.1.2. 准备 1.1.3. 单向外键关联 1.1.3.1. 通过丈夫访问妻子 1.1.3.2....从One的一方访问Many的一方(@OneToMany) 1.2.3.2. 从Many的一方查询One的一方(@ManyToOne) 1.2.4. 双向外键关联 1.2.4.1....总结 Hibernate关联关系 一对一 背景 在中国一个丈夫只能有一个妻子,那么丈夫和妻子的关系就是一对一的关系 准备 创建丈夫和妻子的实体类 丈夫的实体类 @Entity @Table(name...直接将丈夫对应的表的wifeId设置为其他或者为空即可 * * 下面我们使用的是设置丈夫对应的wifeId为空,那么就可以删除其对应的妻子的数据 */ @Test public void...,就是表示当前类的主键将会作为外键 */ @OneToOne(mappedBy="wife") //设置关联,并且将维护权交给了对方类中的属性wife,因此这里的外键就是wifeId public

    6.9K30

    Hibernate学习笔记 多表映射

    前面说了Hibernate的单表映射,由于是实体类和数据表之间一对一的映射,所以比较简单。现在就来说说多表映射,这需要涉及到多个实体类和数据表之间的关系。因此稍微复杂一点。...需要注意在双向注解中,OneToMany需要额外一个参数,mappedBy,指定ManyToOne注解那一边的属性名,这样Hibernate才会明白这是一个双向注解。...OneToOne 一对一映射也是一种常用的映射关系。比方说我们要实现用户头像的功能。由于用户上传的头像文件大小可大可小,因此不能放在用户表中。...=" + id + '}'; } } 然后需要更新Author类: @OneToOne private Avatar avatar; 这样单向一对一映射就完成了...@OneToOne private Author author; 作者类同样需要更新,一旦使用双向映射,就需要添加mappedBy属性。这里添加cascade以便可以级联更新头像表。

    2.1K10

    Hibernate 注解配置

    getter方法上面,请看示例3.7,将Category类的name属性(版块分类名称)映射到了“name”列,并声明该属性为非空、不可编辑、唯一的,限制长度为200: ​示例3.7​ @Column(...return this.id; } 如果SEQ_ID不存在,Hibernate会创建该序列;allocationSize=1配置每次增加的数,默认值: 50;默认情况下,JPA 持续性提供程序使用的分配大小为...如果是Hibernate创建的序列,即使指定initialValue=100,序列也不会从100开始;而是从1开始,因为Hibernate创建序列的时候指定的最小值是1。...setter方法 } 1.1 实体关联关系映射 Hibernate提供了以下注解用于配置实体关联关系: l @OneToOne,用于配置一对一关系 l @OneToMany,用于配置一对多关系 l @ManyToOne...Hibernate提供了哪些注解用于配置实体关联关系()。 A. @OneToOne,用于配置一对一关系 B. @OneToMany,用于配置一对多关系 C.

    96510

    如何在 Spring Boot 中 读写数据

    (1)@OneToOne @OneToOne 用来表示一对一的关系,放置在主导类上。...比如用户类会有一个指定密码表的主键 pwd_id,将 @OneToOne 放置在用户类的 pwd 字段上,就可以表示用户类与密码类是一对一的关系,并且主导类是用户类。...@OneToOne @JoinColumn(name = "pwd_id") private Password pwd; 也可以不使用 @JoinColumn,Hibernate 会自动在用户表生成关联字段...private List user; 如果不指定@JoinColumn 注解,Hibernate会自动生成一张中间表来对用户和部门进行绑定,这张中间表默认的命名规则为:实体类表名_实体类中指定的属性名...name 属性用于指定当前实体类(部门)所对应表的关联 ID;inverseJoinColumns 属性用于指定所关联的实体类表(员工)的关联 ID,里面内嵌了 @JoinColumn 注解。

    18.3K10

    Hibernate关联查询

    Hibernate关联查询 1.1. 关联查询之延迟加载(lazy) 1.1.1. 什么是延迟加载 1.1.2. 什么是关联查询的延迟加载 1.1.3. 一对一 1.1.3.1....多对多 Hibernate关联查询 关联查询之延迟加载(lazy) 什么是延迟加载 前面单独讲过延迟加载就是在根据id查询获取的对象中只是有一个id的属性值,只有当使用其他属性的时候才会发出sql语句查询数据库...,只有当需要使用另外一张表的对象中的属性时才会发出sql语句查询另外一张表 一对一 在一对一的关系中默认使用的不是延迟加载,而是饿汉式的加载方式(EAGER),即是查询一个对象,并且也会随之查询另外一个对象的数据...this.id = id; } @OneToOne(fetch=FetchType.LAZY) //设置wife的主键为Husband的外键,默认的对应表中的字段为wife_id @JoinColumn...@OneToOne都设置fetch属性的值为懒加载 一对多或者多对一 如果是@ManyToOne的方式,那么默认的就是EAGER方式进行查找。

    1.5K10

    JPA作持久层操作

    ) //生成策略,这里配置为自增 @Column(name = "id") //对应表中id这一列 @Id //此属性为主键 int id; @Column...对多:需要多的那方原本就有字段,才可以用该字段对应注解这方的主键 一对一 而用户信息和用户详细信息之间形成了一对一的关系,那么这时我们就可以直接在类中指定这种关系: @Data @Entity @Table...在本表中创建detail_id,并外键连接AccountDetail表的主键id @OneToOne //声明为一对一关系 AccountDetail detail;...") @Id int id; @OneToOne //一对一对应到学科上 @JoinColumn(name = "cid") Subject subject...@JoinColumn(name = "tid") //存储教师ID的字段,和一对一是一样的,也会在当前表中创个外键tid,对应Teacher表的主键 Teacher teacher; //执行的代码

    1.6K10

    node 数据库ORM框架TypeORM入门

    到javascript对象属性 提供表的一对一,多对一,一对多,多对多关系处理 还有更多 … 不同于其他的JavaScript ORM,TypeORM使用的是数据映射模式,可以很轻松的创建出松耦合、可伸缩...一对一关系 来创建与另一个类的一对一关系。 新建PhotoMetadata.ts用来存photo的元信息。...(type => Photo) @JoinColumn() photo: Photo; } 这里我们用到了一个新的装饰器@OneToOne,它可以用来在两个实体之间创建一对一关系。...译者注:也就是上面的author虽然属性是Author,但在数据库中类型是Author id的类型,存的也是id 执行上面的代码将会自动创建author表,如下: +-------------+----...并且name是”My”或”Mishka”, 得到的结果会从第5个开始(分页偏移决定的), 并且只会得到10个结果(分页每页个数决定的), 所得结果是以id的倒序排序的, Photo的albums是左联接

    9.6K31

    JPA实体类中的注解

    ,例如我们用hibernate实现的就是有hibernate来控制   GenerationType总共有四个:   AUTO:   TABLE:由一个表来维护主键,这个表记录上一次生成的主键,然后+1...  标注于属性上,有很多功能,例如指定长度、是否为空,列名以及对应到数据库汇中的类型等,如@Column(length,nullable,name)   例如,我们string对应到数据库中的text就可以这样写...一对一 @OneToOne(mapperBy="",cascade={CascadeType.*}) 随便一端都可以作为关系维护端 通过mapperBy指定为被维护端 fetch默认为立即加载 外键则在关系维护端定义...@Id @Id设置对象表示符,标识的实体类的属性映射对应表中的主键 @GeneratedValue 设置标识符的生成策略,常与@Id一起使用  参数:strategy指定具体的生成策略  方式一:@...ORM框架默认其注解为@Basic @OneToOne 描述一个一对一的关联  可选  fetch:表示抓取策略,默认为FetchType.LAZY  cascade:表示级联操作策略 @ManyToOne

    5.2K70

    springboot整合H2(内置一个月对JPA的学习)

    Hibernate3.2+、TopLink 10.1.3以及OpenJPA都提供了JPA的实现。 JPA的总体思想和现有Hibernate、TopLink、JDO等ORM框架大体一致。...,执行CRUD操作,框架在后台替代我们完成所有的事情,开发者从繁琐的JDBC和SQL代码中解脱出来。...效果如下: 混淆点: @JoinColumn(name = "student_id",referencedColumnName = "id") name = 本表的属性 referencedColumnName...注解忽略sudent中的user属性,这样就不会有循环序列化的问题了 修改user实体类 /** * 一对一关联 用户关联学生表 */ @OneToOne @JsonIgnoreProperties...} } 效果: 更新user会自动更新student,注意要传递student的id 不然会一直执行保存 /** * 一对一双向测试 * @param user * @return */ @DeleteMapping

    4.2K10

    Hibernate SoftDelete 注解: 实现软删除

    Hibernate SoftDelete 注解 1、简介 在本文中,我们将看到如何使用 Hibernate 的 @SoftDelete 注解来为 JPA 实体启用软删除功能。...private Long id; @NaturalId private String name; } @SoftDelete 注解是在 Hibernate 6.4 中引入的...Post 实体,它有一个一对一的 PostDetails 子实体: Post post = new Post() .setId(1L) .setTitle("High-Performance...在 PostComment 被软删除后,Hibernate 会在尝试直接通过 find 方法或间接通过获取 comments 集合时隐藏 PostComment 实体: Post post = entityManager.find...如果你喜欢这篇文章,我相信你也会喜欢我的书和视频课程。 7、结论 与我们之前必须实现的机制相比,Hibernate @SoftDelete 注解非常容易使用。

    58700
    领券