我正在使用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; }
由于您正在使用PreparedStatement,因此可以致电executeUpdate()-
PreparedStatement
executeUpdate()
int count = stmt.executeUpdate(); action = (count > 0); // <-- something like this.
通过上面的Javadoc( Return )链接,添加了重点,
(1) SQL数据操作语言 (DML)语句 的 行数 ,_或者(2)0不返回任何内容的SQL语句 _的 _ 行数_ 。
如果您要插入大量条目,我更喜欢addBatch()和executeBatch()。
addBatch()
executeBatch()