doudunyi3796 2016-03-19 18:00
浏览 8
已采纳

Mysqli从中选择

public function checkIfItemLeft($itemNameSecond){
        $query = "SELECT itemLeft 
                  FROM items
                  WHERE itemName = '$itemNameSecond' 
                  AND itemLeft > 0 Limit 1";
        if(mysqli_query($this->db->getDb(), $query)) {
            return true;
        }
        mysqli_close($this->db->getDb());
        return false;
    }

How do I check if itemLeft is greater than 0?

  • 写回答

1条回答 默认 最新

  • dox90448 2016-03-19 18:10
    关注

    The query could also be done like

    $query="SELECT CASE WHEN itemLeft>0 THEN 1 ELSE 0 END 
            FROM items 
            WHERE itemName = '$itemNameSecond'";
    $result=mysqli_query($this->db->getDb(), $query);
    if ($result) {  // the condition is necessary in case not record exists ...
      $row = mysqli_fetch_row($result);
      $largerthan0 = $row[0];  // will contain 1 if the value was >0
    } 
    else {
      $largerthan0 = 0;
    }
    

    Just thought of a shorter alternative:

    public function checkIfItemLeft($itemNameSecond){
     $query="SELECT COUNT(*) FROM items 
             WHERE itemName = '$itemNameSecond' AND itemLeft>0";
     $result=mysqli_query($this->db->getDb(), $query);
     $row = mysqli_fetch_row($result);
     return ($row[0]>0);
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)