我要去开门见山:PDO数据库未返回行,只返回查询字符串(PDO对象)
MySQL数据库 TBL = mycars_gallery
|id| car_id|img_thumb |img_link |
-----------------------------------
|5 | 3 |thumb1.jpg|image1.jpg|
|6 | 3 |thumb2.jpg|image2.jpg|
|7 | 3 |thumb3.jpg|image3.jpg|
我有2个类:
Upload.class.php
class Upload
{
function __construct()
{
// nothing
}
function deleteCarImgs($car_id,$arr_imgids)
{
//weld all img ids and separate by commas
$img_ids = implode(",",$arr_imgids);
$sql = "SELECT img_link, img_thumb ";
.= "FROM mycars_gallery WHERE car_id = :carid AND id IN(:imgids);";
$params = array(
":carid" => $car_id,
":imgids" => $img_ids
);
//DB processing happens in Database class(100% working)
$dbconn = new Database;
$rows = $dbconn->dbProcess($sql, $params); //doesnt run
}
}
Cars.class.php
class Cars
{
function __construct()
{
// nothing
}
function deleteCompleteCar(3)//car_id is 3
{
$upload = new Upload();
$arr_imgids = array(5,6,7);//these are img_id = 5,6,7 the ones I want to select
$res = $upload->deleteCarImgs($id,$arr_imgids);
var_dump($res);
}
}
的var_dump消息:
PDOStatement Object ( [queryString] => SELECT img_link, img_thumb FROM mycars_gallery WHERE car_id = :carid AND id IN(:imgids);)
我需要什么: 所有其他功能都正常工作,但对于这个特殊的班级,似乎被打破。绝对没有发生错误。而不是获取图像链接和大拇指,只有查询显示时,我使用vardump。我有一种感觉,它与两个互相交流的课程有关。
我已经做了:
- 我跑SQL查询直接很多次,它的工作原理
- 我通过其他类跑数据库PDO的功能,它的工作原理
- 我也试图摆脱implode()并将单个数字字符串'7'传递给:imgsid令牌,仍然没有运气,它实际上返回NULL,而不是PDO obj
多谢先进。
如果你删除行,你不会得到一些行数的结果;相反,数据库只会报告它做了什么。只有选择你会回到行。 –
@Nathaniel Ford我知道,这就是为什么我只使用select来检查查询是否会运行 – Tatarin