0

这是应用程序的一小部分,用户可以在其中注册任意数量的员工,并且员工 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);
            }
                }       
            }
        });
4

3 回答 3

0

为什么不在数据库中创建一个字段,将其设置为 autoIncrementTrue 并且也可以将其用作 ID。您也可以将此字段用作员工编号。

您可以查看此链接以获取更多信息:http ://www.w3schools.com/sql/sql_autoincrement.asp

每次插入新员工时,生成的数字都会增加。

于 2012-10-04T12:38:48.840 回答
0

您可以使用 Oracle、MySQL、PostGre 等数据库,并使用序列或自动生成的 ID 列为您执行此操作

于 2012-10-04T12:39:20.470 回答
0

执行此操作的标准 SQL 方法是使用“自动增量”主键 (emp_code),对于hsqldb ,请参阅 IDENTITY。在 SQL INSERT 语句中省略主键。现在数据库生成一个唯一的新密钥。执行后,您可以使用getGeneratedKeys从语句中检索生成的主键。

这确保了两个并行进程不会弄乱主键。

于 2012-10-04T12:44:35.710 回答