账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    mysqli 与 try catch 如何丢出例外?
    42
    0

    首先我是用 mysqli class 连接资料库

    $do = new mysqli($servername, $username, $password, $mysqldb);

    假设有一个 query 是这样

    $do->query(
          "DELETE FROM `xxx`
          WHERE `id` = x "
        );

    我要怎么判断他是否有正确执行且 throw new Exception
    我的想像是这样就可以了是吗

    $DDD = $do->query(
          "DELETE FROM `xxx`
          WHERE `id` = x "
        );
        
    if (!$DDD) {
        throw new Exception('ERROR!');
    }

    如果是循环呢?怎么判断是否有错误并丢 throw new Exception?

    $record = $do->query(
        "SELECT * FROM `order_record`
        WHERE `x` = 'x' "
      );
    
      foreach ($record as $row) {
        // ...
      }

    如果抓到例外,在 Exception 中加入 $do->rollback() 上面的执行或删除确定都会恢复?

    try {
        // ...
    } catch (Exception $e) {
      $do->rollback();
    }

    PS 我 mariadb 使用 InnoDB 类型

    0
    打赏
    收藏
    点击回答
    您的回答被采纳后将获得:提问者悬赏的 10 元积分
        全部回答
    • 0
    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部