1

我的问题是,当我创建借记卡时,我可以看到它在数据库中创建,但是我稍后在方法中更改的“金额”永远不会反映到数据库中,我在这里缺少什么?

void createDebit(){

  Debit debit=new Debit();
  entityManager.persist(debit);
  entityManager.merge(debit);       
  entityManager.flush();

 //calculate some stuff, do other things

  debit.changeAmount(100);
  entityManager.merge(debit);   
  entityManager.flush(); 
}
4

1 回答 1

0

在使用所需数据设置 bean 后,您需要保留数据。当您第一次坚持时,您似乎没有设置任何内容,因此如果您有一些自动生成的键,那么它在表中可见并且该列的其余部分似乎可以为空。在第二个块中,当您尝试合并时,您应该首先获取存储在 DB 中的数据,然后在其上设置数量。这应该有效。

虽然我不明白你为什么要分两个阶段保存这样的数据。

void createDebit(){

  Debit debit=new Debit();
  entityManager.persist(debit);
  entityManager.merge(debit);       
  entityManager.flush();

 //calculate some stuff, do other things
***//Get Above Debit data from DB and then set amount.***

  debit.changeAmount(100);
  entityManager.merge(debit);   
  entityManager.flush(); 
}
于 2013-06-03T11:27:31.240 回答