您如何确定使用Java和MySQL插入或更新是否成功?

我正在使用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()-

 int count = stmt.executeUpdate();

action = (count > 0); // <-- something like this.

通过上面的Javadoc( Return )链接,添加了重点,

(1) SQL数据操作语言 (DML)语句 的 ,_或者(2)0不返回任何内容的SQL语句 _的 _ _ 。

如果您要插入大量条目,我更喜欢addBatch()executeBatch()

以上是 您如何确定使用Java和MySQL插入或更新是否成功? 的全部内容, 来源链接: utcz.com/qa/425736.html

回到顶部