【发布时间】:2012-10-04 12:33:48
【问题描述】:
这是应用程序的一小部分,用户可以在其中注册任意数量的员工,员工 ID 是通过使用 while 循环生成的……当我关闭应用程序并在第二轮再次开始填充数据时……员工 ID empid 的值重置为零。好吧,只要应用程序正在运行,我就会得到所需的 o/p,即为每个员工分配一个唯一的 ID。每当我启动应用程序时,我不希望 empid 的值从 0 开始。需要替代品和/或任何修改。此处提供代码
int empcount=0;
public void actionPerformed(ActionEvent ae) {
//---------------------If user wants to add data
if(ae.getActionCommand()=="ADD EMPLOYEE") {
System.out.println("ADDING");
try{
empcount=empcount+1;//----------------will assign employees with unique emp id
//--------------------returns the text in name field to variables
String s_name=name.getText();
int s_code=empcount;
String s_dept=dept.getText();
String s_ph=ph.getText();
String s_bg=bg.getText();
String s_add=add.getText();
String s_date=date.getText();
PreparedStatement st=null;
Connection con = null;
Class.forName("org.hsqldb.jdbcDriver");
con = DriverManager.getConnection("jdbc:hsqldb:hsql://localhost/", "SA", "");
st=con.prepareStatement("Insert into EmpReg (emp_name,emp_code,emp_ph,emp_bg,emp_add,emp_date,b_id) values(?,?,?,?,?,?,?)");
//---------------------parameters and respective values, passed to the SQL statement
st.setString(1,s_name);
st.setInt(2,s_code);
st.setString(3,s_ph);
st.setString(4,s_bg);
st.setString(5,s_add);
st.setString(6,s_date);
st.setString(7,s_dept);
st.execute();
JOptionPane.showMessageDialog(null,"Data is inserted into the database");
JOptionPane.showMessageDialog(code, "employee code"+ empcount+"");
con.close();
}
catch(Exception Ee){
System.out.println(Ee);
}
}
}
});
【问题讨论】:
-
empid 的文本字段不可编辑
-
如果你有数据库,要么让数据库为你生成 ID,要么直接使用自己的序列来每次检索新值。作为最后的手段,在启动时您可以轻松调用
SELECT MAX(empid) from TABLE EMPLOYEE并相应地增加值,但要注意需要同步访问值的多线程 -
您应该将数据库连接代码删除到后台线程,而不是在事件调度线程上查询数据库
-
@DavidKroukamp 不这么认为,只是一个初学者:p...无论如何听起来不错...
-
@Robin 是的,你在几小时前告诉过...我会这样做,主要关注的是 empid 的价值
标签: java sql database primary-key sequence