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

标签 java mysql jdbc insert-update

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

相关文章:

php - 管理页面访问

PHP/MySQL - 不允许我插入(或替换)右单引号 "’ "

java - 如何使用ResetAbandonedTimer避免由于removeAbandonedTimeout而关闭连接

sql-server - JDBC 驱动程序连接到 SQL Server 时出现 SSl 握手验证错误

java - 按子列表的值对 LIst 列表进行排序

java - 直接邻居关系密码查询性能

java - hibernate中删除相关对象

Mysql,在过程中声明游标之前插入

jdbc - 在 Pentaho 数据集成工具中更改默认的 jdbc 驱动程序类

java - 使用 HashMap(String, ArrayList<String>)