1

我试图选择一个user id( uID) 只是为了检查它是否存在......我被困在最基本的选择语句中......

我搜索并尝试了不同人的代码,但要么我的代码总是返回 true(如果我不使用 fetch),要么它说它不是一个对象,我不能不使用 fetch....

$sql = 'SELECT uID FROM ldc_user_details where uID=3';
$q = $this->db->prepare($sql);
$i=$q->execute();

     foreach ($i->fetch() as $key => $val){
      echo 'key='.$key." val =".$val;
     }

ERROR: Call to a member function fetch() on a non-object in /home/pdwdev/public_html/ldc_main.php
4

2 回答 2

4

您需要调用 fetch on $q,而不是$iexecute返回一个指示成功或失败的布尔值。

 if($i){ //indicates whether the query succeeded
     foreach ($q->fetchAll() as $key => $val){
         echo 'key='.$key." val =".$val;
     }
 }

请注意,我正在使用fetchAll获取所有行。fetch将只返回一个,并将指针前进到下一行。

于 2012-11-14T12:36:51.817 回答
2
<?php

$sql = 'SELECT uID FROM ldc_user_details where uID=3';

// no need to use prepare() here unless there's a user input

$q = $this->db->query($sql);

// a check for rowCount would be good
if ($q->rowCount() > 0) {

    // all results will be in $i
    $i = $q->fetchAll();

     foreach ($i as $key => $val){

         echo "Key : {$key} <br> Val : {$val}";
     }
}
else {
    die("Zero Results returned");
}

?>

于 2012-11-14T12:44:19.037 回答