我正在尝试选择一个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
答案 0 :(得分:4)
您需要在$q
上调用抓取,而不是$i
。 execute
返回一个表示成功或失败的布尔值。
if($i){ //indicates whether the query succeeded
foreach ($q->fetchAll() as $key => $val){
echo 'key='.$key." val =".$val;
}
}
请注意,我使用fetchAll
来获取所有行。 fetch
将只返回一个,并将指针前进到下一行。
答案 1 :(得分: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");
}
&GT;