gpt4 book ai didi

java - 在 Spring 框架中,从数据库中获取保存的实体以与修改后的未保存实体进行比较

转载 作者:行者123 更新时间:2023-12-03 21:46:10 25 4
gpt4 key购买 nike

使用 Java 和 Spring,我有一个已修改但尚未持久化的实体。我想将它与它的原始状态进行比较,即数据库中仍然存在的状态。但是,当我为实体获取旧状态时,它总是返回处于已修改状态的实体。


为了更好地说明这一点,下面显示了一个示例。

  • MyEntity 类表示实体。
  • MyEntityRepository 类是一个 Spring Data Repository用于为 MyEntity 实体执行数据库交互。
  • MyService 类有一个名为 save 的事务方法,它将新版本的 MyEntity(称为 entity)与 oldEntity< 进行比较。如果entityoldEntity不同,则将entity存入数据库;否则,它不会被保存。

oldEntity 从存储库中获取并与 entity 进行比较。但是,完成此操作后,oldEntity 始终entity 相同。 (entity 中更改的值反射(reflect)在 oldEntity 中。)

由于 entity 尚未保存,我如何获取实体的状态,因为它当前存在于数据库中而不是当前上下文中?是否可以使用 Spring 注释或设置传播值以超出当前持久性上下文来获取实体,以便它是真实的持久值而不是当前上下文中的值?


@Service
public class MyService {
@Autowire
private MyEntityRepository repository;

@Transactional
public boolean save(MyEntity entity) {
MyEntity oldEntity = repository.findOne(entity.getId());
if (entity.compareTo(oldEntity) != 0) {
repository.save(entity);
}
}
}

public interface MyEntityRepository extends PagingAndSortingRepository<MyEntity, Long> {
MyEntity findByName(String name);
}

@Entity
public class MyEntity {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
protected Long id;

@Column(nullable = false)
protected String name;

public Long getId() { ... }
public void setId(Long id) { ... }
public String getName() { ... }
public void setName(String name) { ... }
public int compareTo(MyEntity entity) { ... }

}

最佳答案

您需要牢记事务如何与实体一起工作的行为。当您执行 MyEntity entity = myEntityRepository.findByName("test"); 并在事务中调用类似 entity.setName(); 的内容时,一旦事务完成数据库中的名称列将被更新。在调用 setName 停止更新数据库之前,您需要使用实体管理器删除事务中的实体。但如果您想保存对名称的更改,则需要重新添加它。

关于java - 在 Spring 框架中,从数据库中获取保存的实体以与修改后的未保存实体进行比较,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41842463/

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