J'ai un PreparedStatement tel que:
PreparedStatement preparedStatement = connect.prepareStatement("INSERT into employee (id, time, name" + "(?,?,?)",Statement.RETURN_GENERATED_KEYS);
ResultSet tableKeys = preparedStatement.getGeneratedKeys();
preparedStatement.executeUpdate();
tableKeys.next();
int autoGeneratedID = tableKeys.getInt(1);
preparedStatement.setInt(1,autoGeneratedID);
preparedStatement.setTimestamp(2, new Java.sql.Timestamp(new Java.util.Date().getTime()));
preparedStatement.setString(3, "Test");
preparedStatement.executeUpdate();
Comme vous pouvez le constater, la table Employé a un ID auto-incrémenté. En gros, je dois l’ajouter automatiquement à l’aide de readyStatement. Quelqu'un peut-il me dire où je me trompe et me corriger? Pour le moment, cela me donne simplement une erreur liée à Statement.
Laissez la colonne en dehors de la déclaration INSERT
entièrement . Il sera généré par le moteur de base de données. Votre requête devrait être:
INSERT INTO employee (time, name)
VALUES (?, ?)
Deuxièmement, vous devez d'abord insérer l'insertion, puis extraire les clés du résultat.
Je crois que votre code devrait être:
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);
Notez que cet exemple ne vérifie pas le succès de l'instruction exécutée ni l'existence de clés renvoyées.
try{
Class.forName("Oracle.jdbc.driver.OracleDriver");
Connection con = DriverManager.getConnection("jdbc:Oracle:thin:@localhost:1521:xe","system","password");
PreparedStatement ps = con.prepareStatement("insert into imgslider(id,cmnt,date1,img,status) values(seq.nextval,?,?,?,?)");
ResultSet rs = null;
String s1 = "I’ve Come and I’m Gone: A Tribute to Istanbul’s Street";
ps.setString(1,s1);
Calendar calendar = Calendar.getInstance();
Java.sql.Date dd = new Java.sql.Date(calendar.getTime().getTime());
ps.setDate(2,dd);
FileInputStream f1 = new FileInputStream("F:\\Java\\slide-9.jpg");
ps.setBinaryStream(3,f1,f1.available());
ps.setInt(4,0);
int i = ps.executeUpdate();
System.out.println(i+" rows affected");
con.close();
}
voici mon code pour la colonne auto-incrémentée dans la table par PreparedStatement.