可能是一个新手Java的东西,但它在这里。使用JPA调用INSERT存储过程到Oracle 11g数据库。在将数据传送到数据库表格方面,一切正常。Java Swing/JPA/Oracle插入两次
我已经将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();
}
}
如果你所删除'列出结果= q.getResultList();'(及以下几行)? – 2012-07-12 09:35:02
我这样做的共振是从Insert SPROC中获取新创建的ID和OUT参数。 SPROC有一个Sequence.nextVal的触发器。 – Beachdog 2012-07-12 16:45:38