0

我遇到了这个奇怪的问题,我的 merge() 或 persist() 函数没有反映在数据库中。我的 JdbcProductDao.java:

@Repository("productDao")
public class JdbcProductDao implements ProductDao {
    @PersistenceContext
    private EntityManager entityManager;

    public JdbcProductDao(){
    }

    public Product getReference(Product product){
      return getEntityManager().getReference(product.getClass(),product.getId());
    }

    public void persist(Product product){
        getEntityManager().persist(product);
    }

    public EntityManager getEntityManager(){
        return entityManager;
    }

    public void setEntityManager(EntityManager entityManager){
        this.entityManager = entityManager;
    }

    @SuppressWarnings("unchecked")
    public List<Product> getProductList(){
        return getEntityManager().createQuery("from Product").getResultList();
    }

    public void saveProduct(Product product){
        persist(product);
    }
}

我的getProductList()工作正常,但是我的 saveProduct 对数据库没有任何作用。

你能想到会发生这种情况的任何原因吗?

我将发布我的 Product.java 文件:

@Entity
@Table(name="products")

public class Product implements Serializable {
    @Id
    @Column(name = "id")
    private int id;
    @Column(name = "description")
    private String description;
    @Column(name = "price")
    private Double price;

    public void setId(int i) {
        id = i;
    }

    public int getId() {
        return id;
    }

    public String getDescription() {
        return description;
    }

    public void setDescription(String description) {
        this.description = description;
    }

    public Double getPrice() {
        return price;
    }

    public void setPrice(Double price) {
        this.price = price;
    }

    public String toString() {
        StringBuffer buffer = new StringBuffer();
        buffer.append("Description: " + description + ";");
        buffer.append("Price: " + price);
        return buffer.toString();
    }
}
4

2 回答 2

4

尝试在 EntityManager persist() 之后调用 flush() 方法。

public void persist(Product product){
    getEntityManager().persist(product);
    getEntityManager().flush();
}
于 2010-01-16T08:27:57.413 回答
1

这可能不是您需要的答案,但是既然您已经在使用 Spring,为什么不通过使用 Spring 持久性模板(例如 jpaTemplate)来简化您的 DAO 生活。我的 DAO 看起来像这样:

    @Override
@SuppressWarnings("unchecked")
public List<Sample> findAll() {
    return jpaTemplate.find("from Sample");
}

    @Override
public Sample findById(Long sampleId) {
    return jpaTemplate.find(Sample.class, sampleId);
}

    @Override
public Sample store(Sample dp) {
    return jpaTemplate.merge(dp);
}
于 2010-01-16T08:04:23.840 回答