gpt4 book ai didi

java - 在 persist() 之后、flush() 之前更改 JPA 实体不起作用

转载 作者:行者123 更新时间:2023-11-30 04:38:49 25 4
gpt4 key购买 nike

我正在使用 JPA 2 和 Hibernate 版本。 4.1.7.Final 作为 JPA 实现。为了清楚起见,我还使用 Spring 框架 v.3.1.2.RELEASE。这就是我的问题。

我编写了一个方法来添加/更新我的用户实体。

@Override
@Transactional
public void saveUser(UserForm userForm) {
User user;

if (userForm.getId() == null) { // new user
user = new User();
user.setCreationDate(new Date());
entityManager.persist(user); // !!!
} else {
user = entityManager.find(User.class, userForm.getId());
}

user.setFirstName(userForm.getFirstName());
user.setLastName(userForm.getLastName());
user.setMiddleName(userForm.getMiddleName());

user.setEmail(userForm.getEmail());

user.setRole(entityManager.find(Role.class, 1));//TODO

user.setLogin(userForm.getLogin());
user.setPassword(userForm.getPassword1());

entityManager.flush();
}

我正在测试添加用户(userForm.getId() == null)。上面的代码不起作用,给出错误:

javax.persistence.PersistenceException: org.hibernate.exception.ConstraintViolationException: Column 'first_name' cannot be null
at org.hibernate.ejb.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1377)
at org.hibernate.ejb.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1300)
at org.hibernate.ejb.AbstractEntityManagerImpl.convert(AbstractEntityManagerImpl.java:1306)
at org.hibernate.ejb.AbstractEntityManagerImpl.flush(AbstractEntityManagerImpl.java:989)
...

但是。如果我将对 persist() 的调用移到lush() 之前的末尾,则一切正常:

@Override
@Transactional
public void saveUser(UserForm userForm) {
User user;

if (userForm.getId() == null) { // new user
user = new User();
user.setCreationDate(new Date());
} else {
user = entityManager.find(User.class, userForm.getId());
}

user.setFirstName(userForm.getFirstName());
user.setLastName(userForm.getLastName());
user.setMiddleName(userForm.getMiddleName());

user.setEmail(userForm.getEmail());

user.setRole(entityManager.find(Role.class, 1));//TODO

user.setLogin(userForm.getLogin());
user.setPassword(userForm.getPassword1());

entityManager.persist(user);// !!!
entityManager.flush();
}

我认为发生的情况是在第一种(问题)情况下,它尝试存储持久调用时存在的用户对象数据,尽管实际保存是在flush()期间执行的(upd。错误。它尝试在 persist() 调用时发出 sql 插入。让我这样想的是,当我尝试调试时,我发现它仍然尝试在内部某处插入正确的creation_date,但其他值都是空。

但我发誓,在我几年前从事的其他项目中,这工作得很好,尽管后来我使用了 Oracle 而不是 MySQL(我不认为这是原因)和旧版本的框架。

这里可能出现什么问题?也许 Hibernate 的一些配置选项会影响这个?

或者这是正确的行为和我对 JPA API 的误解?

UPD。我正在使用

@Id
@GeneratedValue
@Column(columnDefinition="INT")
private int id;

用于用户条目中的 id 字段。我相信这意味着生成策略= AUTO,这适用于mysql auto_increment key。

最佳答案

您将用户名设置为 null (user.setFirstName(userForm.getFirstName());),因为 userForm.getFirstName() 返回 null,并且您的错误显示:列“first_name”不能为空

您应该检查为什么 userForm.getFirstName() 返回 null 或允许用户的名字为 null,因为您当前的实体配置不允许这样做。

也许您可以向我们展示用户实体?

关于java - 在 persist() 之后、flush() 之前更改 JPA 实体不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12788808/

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