EntityManager объединить / сохранить проблему - PullRequest
0 голосов
/ 16 января 2010

У меня странная проблема, когда мои функции 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();
    }
}

Ответы [ 2 ]

4 голосов
/ 16 января 2010

попробуйте вызвать метод flush () после того, как EntityManager persist ().

public void persist(Product product){
    getEntityManager().persist(product);
    getEntityManager().flush();
}
1 голос
/ 16 января 2010

это может быть не тот ответ, который вам нужен, но, поскольку вы уже используете Spring, почему бы не упростить вашу жизнь DAO с помощью шаблонов персистентности Spring (например, jpaTemplate). Мой 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);
}
...