SQL中execute操作返回false的问题

博客原文

今天在码代码的时候遇到了一个问题,代码如下:

    SQL一:
                sql = " update t_receive_user set user_email = ?, user_name = ?, user_tel = ?, " +
                        " update_timestamp = ? , note = ?  where user_sid = ? ";
                connection = getDataSource().getConnection();
                ps = connection.prepareStatement(sql);
                ps.setObject(1,tReceiveUser.getUserEmail());
                ps.setObject(2,tReceiveUser.getUserName());
                ps.setObject(3,tReceiveUser.getUserTel());
                ps.setObject(4,Time.getCurrentTime()/1000);
                ps.setObject(5,tReceiveUser.getNote());
                ps.setObject(6,tReceiveUser.getUserSid());
                System.out.println(ps.execute());
    SQL二:
     sql = " delete t_receive_user where user_sid = ? ";
                connection = getDataSource().getConnection();
                ps = connection.prepareStatement(sql);
                ps.setObject(1,tReceiveUser.getUserSid());
                System.out.println(ps.execute());
    SQL三:
    sql = "INSERT t_receive_user (user_email,user_name,user_tel,update_timestamp,note)" +
                        " values (?,?,?,?,?)";
                ps = connection.prepareStatement(sql);
                ps.setObject(1,tReceiveUser.getUserEmail());
                ps.setObject(2,tReceiveUser.getUserName());
                ps.setObject(3,tReceiveUser.getUserTel());
                ps.setObject(4,Time.getCurrentTime()/1000);
                ps.setObject(5,tReceiveUser.getNote());
                System.out.println(ps.execute());

我发现即使我的数据库更新成功、删除成功、增加成功,返回值都是false。

execute内部细节代码如下:

    public boolean execute() throws SQLException {
            synchronized(this.checkClosed().getConnectionMutex()) {
                boolean returnVal = false;
                this.checkStreamability();
                this.setInOutParamsOnServer();
                this.setOutParams();
                returnVal = super.execute();
                if(this.callingStoredFunction) {
                    this.functionReturnValueResults = this.results;
                    this.functionReturnValueResults.next();
                    this.results = null;
                }
    
                this.retrieveOutParams();
                return !this.callingStoredFunction?returnVal:false;
            }
        }

查资料发现:boolean execute() throws SQLException在此 PreparedStatement 对象中执行 SQL 语句,该语句可以是任何种类的 SQL 语句。一些特别处理过的语句返回多个结果,execute 方法处理这些复杂的语句;executeQuery 和 executeUpdate 处理形式更简单的语句。 execute 方法返回一个 boolean 值,以指示第一个结果的形式。必须调用 getResultSet 或 getUpdateCount 方法来检索结果,并且必须调用 getMoreResults 移动到任何后面的结果返回:如果第一个结果是 ResultSet 对象,则返回 true;如果第一个结果是更新计数或者没有结果,则返回 false,意思就是如果是查询的话返回true,如果是更新或插入的话就返回false了;execute()返回的是一个boolean值,代表两种不同的操作啊,getResultSet()返回的是结果集,而getUpdateCount()返回的是更新的记数。

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
.execute(sql)是JDBC的一个方法,用于执行给定的SQL语句。 在JDBC,执行SQL语句是最重要的一个步骤。一般有三个方法可以用来执行SQL语句:executeexecuteUpdate和executeQuery。 具体来说,execute方法用于执行查询语句和DDL语句,它返回一个boolean值,表示是否执行成功。如果执行成功,返回true;如果执行失败或者返回结果是更新数量,则返回false。 在给定的代码示例executeUpdate方法被用于执行添加操作executeUpdate方法用于执行INSERT、UPDATE或DELETE语句,它返回一个int值,表示受影响的行数。 在示例代码,通过执行executeUpdate方法将一个学生信息插入到数据库,并打印出受影响的行数。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [execute(sql)三种执行方法的返回值表示的含义](https://blog.csdn.net/u014644594/article/details/88800256)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [JDBC执行sql语句的方法,executeexecuteUpdate、executeQuery](https://blog.csdn.net/flying_hengfei/article/details/102604620)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值