Pozostaw kolumnę poza INSERT
oświadczenie w całości . Zostanie wygenerowany przez silnik bazy danych. Twoje zapytanie powinno brzmieć:
INSERT INTO employee (time, name)
VALUES (?, ?)
Po drugie, musisz najpierw wykonać wstawianie, a następnie wyciągnąć klucze z wyniku.
Uważam, że Twój kod powinien wyglądać następująco:
PreparedStatement preparedStatement =
connect.prepareStatement("INSERT into employee (time, name) VALUES (?,?)",
Statement.RETURN_GENERATED_KEYS);
preparedStatement.setTimestamp(1,
new java.sql.Timestamp(new java.util.Date().getTime()));
preparedStatement.setString(2, "Test");
preparedStatement.executeUpdate();
ResultSet tableKeys = preparedStatement.getGeneratedKeys();
tableKeys.next();
int autoGeneratedID = tableKeys.getInt(1);
Zauważ, że ten przykład nie sprawdza powodzenia wykonanej instrukcji ani istnienia zwróconych kluczy.