【发布时间】:2014-08-25 14:37:22
【问题描述】:
我在更新记录时遇到问题:
package legacy.database;
import java.sql.Timestamp;
import java.util.ArrayList;
import java.util.List;
import java.util.logging.Logger;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Predicate;
import javax.persistence.criteria.Root;
public class Queries {
private static final Logger log = Logger.getLogger(Queries.class.getName());
private final EntityManagerFactory emf = Persistence.createEntityManagerFactory("LegacyDatabasePU");
private final EntityManager em = emf.createEntityManager();
public Queries() {
}
private List<Clients> findAll() {
Query q = em.createQuery("select c from Clients c");
List<Clients> clients = q.getResultList();
return clients;
}
public Clients findById(int id) {
Clients client = em.find(Clients.class, id);
return client;
}
public void update(Clients c2) {
Clients c1 = em.find(Clients.class, c2.getId());
java.util.Date date = new java.util.Date();
Timestamp t = new Timestamp(date.getTime());
c2.setDateUpdated(t.toString());
em.getTransaction().begin();
c2.setDateUpdated(t.toString());
c1 = c2;
log.info(c1.getNotes());
log.info(c2.getNotes());
em.getTransaction().commit();
}
}
分配 c1=c2 有问题吗?我是否必须手动通过 c1 并更新每条记录?
【问题讨论】:
-
未找到任何使用
EntityManager的更新数据库操作,如em.merge()!!! -
@WundwinBorn:修改附加实体不需要合并。
-
@JBNizet 是的,当然
merge()op 不需要托管实例,但我的意思是 OP 帖子中的分离实例。
标签: java jpa variable-assignment equals jpql