Java上次插入ID无效

时间:2011-12-10 01:57:41

标签: java mysql jdbc last-insert-id

  

可能重复:
  How to get the insert ID in JDBC?

我试图获取最后一个插入ID,但显然它不起作用,它继续给我一堆错误,其中一个就是这个

java.sql.SQLException: Can not issue SELECT via executeUpdate().

我试图获得最后一次插入但它不起作用,这是我的代码

public int getLastInsertID(){
        try{
        Statement statement =  conn.createStatement();
        ResultSet rs = null;
        statement.executeUpdate("SELECT LAST_INSERTED_ID", Statement.RETURN_GENERATED_KEYS);
        rs = statement.getGeneratedKeys();
        while(rs.next()){
            System.out.println(""+rs.getInt(1));
            id =    rs.getInt(1);
            JOptionPane.showMessageDialog(null,id);

        }

        }catch(Exception e){
            e.printStackTrace();
        }

        return id;
    }
}

,第二个是

public void addEmployee(Personal p ,Contact c,Employee e) {
        Statement statement = null;

        String insert0 = "INSERT INTO `finalpayroll`.`users` (`emp_id`, `emp_pass`) VALUES ('2010-010122', '1231922')";
        try{
            statement = conn.createStatement();
            statement.executeUpdate(insert0);
            statement.close();
        }catch(Exception ex){
            ex.printStackTrace();
        }
        id = getLastInsertID();

        String insert1 = "INSERT INTO personal_info (`idpersonal_info`,`First_Name`, `Middle_Initial`, `Last_Name`, `Date_Of_Birth`, `Marital_Status`, `Beneficiaries`) VALUES ("+id+",'"+p.getFirstName()+"', '"+p.getMiddleInitial()+"'" +
                "       , '"+p.getLastName()+"', '"+p.getDateOfBirth()+"', '"+p.getMaritalStatus()+"', '"+p.getBeneficiaries()+"')";
        try{
            statement = conn.createStatement();

        statement.executeUpdate(insert1);
        statement.close();
        conn.close();
        JOptionPane.showMessageDialog(null, "Employee Added!!");
        }catch(Exception ex){
            ex.printStackTrace();
        }


    }

我怎样才能获得最后插入的ID?我的方法有什么问题?

1 个答案:

答案 0 :(得分:0)

看起来它可能是某些版本的mysql驱动程序的错误。在this源代码中搜索错误消息。他们没有检查getGeneratedIds条件。

自2005年以来,MySQL有一个类似的“不会修复”bug。讨论提到他们的驱动程序支持该功能并不要求JDBC API。似乎这是一个已知且未解决的问题。