我使用 JPA 并遇到以下问题,我的表在调用 setter 后会自动更新。这是一个例子:
持久对象:
@Entity
public class Product implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private String id;
String name;
/*+ getters & setters */
}
门面访问我的对象:
@Stateless
public class ProductFacade {
@PersistenceContext(unitName = "PU")
private EntityManager em;
public Product find(Object id) {
Product p = em.find(Product.class, id);
return p;
}
public void create(Product p) {
em.persist(p);
}
}
但是当我在我的 webapp 中执行这段代码时:
@Stateless
public class ProductService {
@EJB
ProductFacade manager;
public void testMethod() {
id = new Long(1);
Product product = manager.find(id);
product.setName("newName");
}
}
即使我没有显式调用持久化或合并,产品的名称值也会在设置后在数据库中更改。
我能做些什么来避免这种自动数据库更改?
这也是我的 persistence.xml :
<persistence .... >
<persistence-unit name="PU" transaction-type="JTA">
<provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
<jta-data-source>jdbc/sample</jta-data-source>
<exclude-unlisted-classes>false</exclude-unlisted-classes>
<properties>
<property name="eclipselink.ddl-generation" value="create-tables"/>
<property name="connection.autocommit" value="false"/>
<property name="eclipselink.persistence-context.flush-mode" value="COMMIT"/>
</properties>
</persistence-unit>
</persistence>
谢谢您的帮助。