Heim > Fragen und Antworten > Hauptteil
Mit Java 1.8
和Spring Framework 4.0.3-RELEASE
versuche ich, eine Zeile in eine MySQL-Datenbank einzufügen, nachdem ich einen Wert von einer externen Quelle erhalten habe.
Versuchen Sie Folgendes:
private static JdbcTemplate jdbcTemplateObject = null; private static final String INSERT_QUERY = "insert into order_table(id,order_id,created_time,updated_time)VALUES(?,?,now(),now())"; parseFeedAndStoreIntoDB() { List<Object[]> insertData = new ArrayList<>(); SqlRowSet sqlRowSet = null; // id, order_id, created_time, updated_time有值 insertData.add(new Object[] {id, order_id, created_time, updated_time}); if (insertData.size() > 0) { // 这里出错了 jdbcTemplateObject.batchUpdate(INSERT_QUERY, insertData); } }
Wenn ich diese Methode ausführe, erhalte ich die folgende Ausnahme:
Exception in parseFeedAndStoreIntoDB() method org.springframework.dao.TransientDataAccessResourceException: PreparedStatementCallback; SQL [insert into order_table(id,order_id,created_time,updated_time)VALUES(?,?,now(), now());]; Parameter index out of range (4 > 3).; nested exception is java.sql.SQLException: Parameter index out of range (4 > 3).
Ich habe die Anzahl der Zeilen gezählt, es gibt 4 Zeilen sowohl in meinem Java-Code als auch in der MySQL-Datenbanktabelle, die ich erstellt habe.
P粉6475042832023-09-13 09:02:50
您的查询在id
和order_id
上有绑定参数,其他两个字段在查询中设置为now()
。将
insertData.add(new Object[] {id, order_id, created_time, updated_time});
改为
insertData.add(new Object[] {id, order_id});
或者将
private static final String INSERT_QUERY = "insert into " + "order_table(id,order_id,created_time,updated_time) " + "VALUES(?,?,now(),now())";
改为
private static final String INSERT_QUERY = "insert into " + "order_table(id,order_id,created_time,updated_time) " + "VALUES(?,?,?,?)";