gpt4 book ai didi

Hibernate OneToOne 映射在插入前执行 select 语句;不知道为什么

转载 作者:行者123 更新时间:2023-12-03 12:06:30 26 4
gpt4 key购买 nike

我在我的实体中配置了一个简单的 OneToOne 映射,但是当我持久化对象时,我看到 Hibernate 在插入之前执行了一个“选择”语句,我不知道为什么。

@Entity 
@Table( name = "USER" )
public class NewUser {

@OneToOne
@JoinColumn(name="user_status_type_id", nullable=false)
private UserStatusType userStatusType;

UserStatusType 只是一个只读查找表,所以当我保存 User 时,该表中没有任何内容。
User u = new User();
u.setUserStatusType( new UserStatusType(101));
session.persis(u);

但是当我持久化 User 对象时,Hibernate 的输出如下:
Hibernate: select userstatus_.user_status_type_id, userstatus_.user_status_name as user2_3_ from USER_STATUS_TYPE userstatus_ where userstatus_.user_status_type_id=?
Hibernate: insert into USER (created, first_name, last_name, password, user_name, user_status_type_id) values (?, ?, ?, ?, ?, ?)

我不知道这对于 Hibernate 是否正常。我想因为这是一个“持久化”操作,所以我只会看到一个 Insert 语句;不确定 Select 的目的。

映射不正确?

最佳答案

好的,我能够从 Hibernate 论坛中得到答案。防止SELECT之前 INSERT , 如果您确定引用的行存在于数据库中,则使用 Session.load()EntityManager.getReference() .

User u = new User();
u.setUserStatusType( session.load(UserStatusType.class, new Long(id));
session.persist(u);
session.load()方法最初不加载任何东西,它只是为对象创建一个代理并避免对数据库的命中。现在,如果您想从 session 上下文中的类访问成员(除了 id 字段),那么 Hibernate 将转到数据库。在我的情况下,我只需要来自 INSERT 的引用对象的主键,所以我避免了数据库命中。

关于Hibernate OneToOne 映射在插入前执行 select 语句;不知道为什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5208334/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com