0

可能是一个新手 Java ......但它就在这里。使用 JPA 调用 Oracle 11g 数据库的 INSERT 存储过程。就将数据获取到数据库表而言,一切正常。

我已将 JPA 代码包装到 Java Swing 应用程序中。我的问题是数据以某种方式提交了两次。我有一个JOptionPane.showMessageDialog在我提交数据时显示的。那只显示一次。但是当我查询表格时,表格中有两个条目。这是我的代码....

按钮代码

JButton btnSubmit = new JButton("Submit");
btnSubmit.addActionListener(new ActionListener() {
    public void actionPerformed(ActionEvent arg0) {
        AddNewCustomer();
    }
});
btnSubmit.setBounds(24, 341, 91, 23);
frmNewCustomer.getContentPane().add(btnSubmit);

动作方法

public void AddNewCustomer() {
    Customer.AddCustomer(this.txtFirstName.getText(),
            this.txtLastName.getText(), this.txtAddress.getText(),
            this.txtCity.getText(), this.txtState.getText(),
            this.txtEmail.getText(), this.txtPhone.getText());

    JOptionPane.showMessageDialog(frmNewCustomer, "Added new customer",
            "Status", 1);
}

protected static void AddCustomer(String sFirstName, String sLastName,
        String sAddress, String sCity, String sState, String sEmail,
        String sPhone) {
    try {
        factory = Persistence
                .createEntityManagerFactory(PERSISTENCE_UNIT_NAME);
        EntityManager em = factory.createEntityManager();
        em.getTransaction().begin();

        Query q = em.createNamedQuery("AddCustomer");
        q.setParameter("p_PHONE", sPhone);
        q.setParameter("p_STATE", sState);
        q.setParameter("p_FIRST_NAME", sFirstName);
        q.setParameter("p_ADDRESS", sAddress);
        q.setParameter("p_EMAIL", sEmail);
        q.setParameter("p_CITY", sCity);
        q.setParameter("p_LAST_NAME", sLastName);
        int r = q.executeUpdate();
        em.getTransaction().commit();

        List results = q.getResultList();
        if (results != null) {
            Object id = results.get(0);
            if (id != null) {
                System.out.println(id.toString());
            }
        }
        em.close();
    } catch (Exception e) {
        e.printStackTrace();
    }
}
4

2 回答 2

0

我解决了这个问题。将代码更改为....

protected static void AddCustomer(String sFirstName,String sLastName, String sAddress, String sCity, String sState,String sEmail,String sPhone )
{

    try {
        factory = Persistence.createEntityManagerFactory(PERSISTENCE_UNIT_NAME);
        EntityManager em = factory.createEntityManager();
        em.getTransaction().begin();

        Query q = em.createNamedQuery("AddCustomer");   
        q.setParameter("p_PHONE", sPhone);
        q.setParameter("p_STATE", sState);
        q.setParameter("p_FIRST_NAME", sFirstName);
        q.setParameter("p_ADDRESS", sAddress);
        q.setParameter("p_EMAIL", sEmail);
        q.setParameter("p_CITY", sCity);
        q.setParameter("p_LAST_NAME", sLastName);
        //int r = q.executeUpdate();                
        //em.getTransaction().commit();

        List results = q.getResultList();
        if(results != null)
        {           
            Object id = results.get(0);
            if(id != null)
            {
                System.out.println(id.toString());
            }
            em.getTransaction().commit();
        }
        em.close(); 
    } catch (Exception e) {

        e.printStackTrace();
    }

}
于 2012-07-13T07:35:37.830 回答
0

您需要删除对 的调用getResultList(),这将再次执行相同的查询(它是插入查询,而不是选择查询)。无论如何,您都不需要它来获取 ID,请参阅此问题。但是,您根本不需要为此使用查询,因为应该使用创建条目的适当方式entityManager.persist(obj)(假设您有一个 JPA 实体,因为无论如何您都在使用 JPA)。

于 2012-07-12T09:50:34.230 回答