Lämna kolumnen utanför INSERT
uttalande helt . Den kommer att genereras av databasmotorn. Din fråga bör vara:
INSERT INTO employee (time, name)
VALUES (?, ?)
För det andra måste du utföra infogningen först och sedan ta ut nycklarna ur resultatet.
Jag tror att din kod bör vara:
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);
Observera att det här exemplet inte kontrollerar framgången för den körda satsen eller förekomsten av returnerade nycklar.