问题描述
由于您正在使用PreparedStatement
,因此可以致电executeUpdate()
-
int count = stmt.executeUpdate();
action = (count > 0); // <-- something like this.
通过上面的Javadoc( Return )链接,添加了重点,
如果您要插入大量条目,我更喜欢addBatch()
和executeBatch()
。
解决方法
我正在使用Java连接到MySQL数据库。我正在尝试向数据库中插入或更新数据。
即使我很确定插入成功,它也会返回false。
根据“执行” 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;
}