gpt4 book ai didi

java - Spring JPA : Saving an entity Object in database

转载 作者:行者123 更新时间:2023-12-02 08:56:58 24 4
gpt4 key购买 nike

我有一个实体CandidateTransactionCandidateTransactionRepository扩展CrudRepository

@Repository
public interface CandidateTransactionRepository extends CrudRepository<CandidateTransaction,Long>{
//find methods


}

@Entity
@Table(name = "ONB_CANDIDATE_TRANS")
public class CandidateTransaction implements Serializable {

private static final long serialVersionUID = 3615632069112078119L;

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Integer ID;
//other columns

我正在使用 CrudRepository 的 save 方法来保存上述实体的对象。当实体不存在行时,它会非常直接地创建一个自动生成的键并将其插入到 ID 列中,而无需 java 端的干预。

由于 CrudRepository 的 save() 方法会检查实体是否是新的,如果是新的,它会保存数据,否则它会调用 merge 方法来更新同一行。

理想情况下,它应该处理这种情况,但在我的情况下,我必须专门检查具有特定值的行是否存在,如果存在,则在现有对象中设置更新的值,然后保存它。

有什么办法可以解决这个问题吗?

if (candidateTransactionRepository.existsByCandidateIdAndTransactionType(candidateId, transactionType))
candidate = candidateTransactionRepository.findByCandidateIdAndTransactionType(candidateId,transactionType);

candidate = prepareTransactionProgressObjectToSave(candidateId, transactionType, transactionStatus);

savedInstance = candidateTransactionRepository.save(candidate);

如果我必须保存同一​​实体的集合怎么办。

最佳答案

Ideally it should handle such case but in my case I have to specifically check whether the row with particular value exists or not, if yes then set the updated values in the existing object and then save it.

主键(属性“ID”)在表中是唯一的。如果在 save() 时实体没有设置主键(IDnull),那么 CrudRepository 会认为该实体之前没有保存过,并在数据库。

您在保存之前进行查找的技术很常见。您通常使用查找器方法 (CrudRepository.findByPROPERTYNAME(...)) 按其他属性/列查找实体。 finder 方法返回的实体将具有非 nullID

Also What if I have to save Collection of the same entity.

CrudRepository.saveAll()是你最好的选择,因为集合是一个 Iterable,因为该方法需要作为参数。

关于java - Spring JPA : Saving an entity Object in database,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60439624/

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