我正在使用 Java 连接到 MySQL 数据库。我正在尝试将数据插入或更新到数据库中。
即使我很确定插入成功,它也会返回 false。
根据“execute” API,返回值为“如果第一个结果是 ResultSet 对象,则返回 true;如果是更新计数或没有结果,则返回 false”。
如何确定我的插入或更新是否成功?
public boolean insertSelections(String selection, String name){
String sql ="INSERT INTO WORKREPORT VALUES (?,?,?,?,?)";
boolean action = false;
try {
PreparedStatement stmt = conn.prepareStatement(sql);
SimpleDateFormat dateFormat = new java.text.SimpleDateFormat("yyyy:MM:dd hh:mm:ss");
String formatDate = dateFormat.format(new java.util.Date(System.currentTimeMillis()));
java.util.Date mDate = dateFormat.parse(formatDate);
java.sql.Timestamp timeStamp = new java.sql.Timestamp(System.currentTimeMillis());
// Date time= new Date(mDate.getTime());
stmt.setInt(1, Integer.parseInt(getNumberByName(name).trim()));
stmt.setString(2, name);
// stmt.setDate(3, time);
stmt.setTimestamp(3, timeStamp);
stmt.setString(4, selection);
stmt.setString(5, "N/A");
action = stmt.execute();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ParseException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return action;
}
最佳答案
由于您使用的是 PreparedStatement
你可以调用 executeUpdate()
-
int count = stmt.executeUpdate();
action = (count > 0); // <-- something like this.
来自上面的 Javadoc (Returns) 链接,已添加重点,
either (1) the row count for SQL Data Manipulation Language (DML) statements or (2) 0 for SQL statements that return nothing.
如果要插入大量条目,我更喜欢 addBatch()
和 executeBatch()
.
关于java - 如何使用 Java 和 MySQL 确定插入或更新是否成功?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24378270/