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

2022-09-01 15:25:34

我正在使用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;
    }

答案 1

由于您正在使用ReadyStatement,因此您可以致电executeUpdate() -

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

从上面的Javadoc(返回)链接,着重号是后加的,

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

如果你想插入大量的条目,我更喜欢addBatch()experactBatch()。


答案 2

首先,您应该知道:

布尔执行()执行此 PreparedStatement 对象中的 SQL 语句,该对象可以是任何类型的 SQL 语句。

ResultSet executeQuery()在此 ReadyStatement 对象中执行 SQL 查询,并返回查询生成的 ResultSet 对象。

int executeUpdate()执行此 PreparedStatement 对象中的 SQL 语句,该语句必须是 SQL INSERT、UPDATE 或 DELETE 语句;或不返回任何内容的 SQL 语句,如 DDL 语句。

        int i = stmt.executeUpdate();
        if (i > 0) {
            System.out.println("success");
        } else {
            System.out.println("stuck somewhere");
        }

尝试一下,看看插入是否发生


推荐