3

我直接进入正题:

Mysql DB 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 节课:

上传.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
}
}

汽车类.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 时,只显示查询,而不是获取图像链接和拇指。我觉得这与 2 个班级之间的互动有关。

我已经做了什么:

  1. 我已经多次直接运行sql查询,它可以工作
  2. 我通过其他类运行数据库 PDO 函数,它可以工作
  3. 我还尝试摆脱 implode() 并将单个数字字符串 '7' 传递给 :imgsid 令牌,仍然没有运气,它实际上返回 NULL,而不是 PDO obj

非常感谢先进。

4

1 回答 1

2

以下是一些您可能会发现有用的发现。首先来自PDO::prepare的 PHP 手册。但是您使用 传递单个字符串implode(),但我认为这仍然是需要牢记的重要事项。

您不能将多个值绑定到单个命名参数,例如 SQL 语句的 IN() 子句。

第二和第三可能是由于错字:

$sql = "SELECT img_link, img_thumb "; // this semi colon will cause syntax error on the next line.
     .= "FROM mycars_gallery WHERE car_id = :carid AND id IN(:imgids);"; 

并且,在您的表结构中,您已显示mycar_id为一列,但您car_id的 where 子句中有。

最后,我不想复制粘贴的可能解决方案,因此您可以实施以下方法来解决该in问题:

PHP PDO:更新 SQL WHERE IN () 子句中的数组

我可以将数组绑定到 IN() 条件吗?

更新:

像这样的东西应该可以工作,但请记住,它$arr_imgids需要是一个数组才能工作:

function deleteCarImgs($car_id, $arr_imgids)
{
    $in_sql = ':imgid' . implode(',:imgid', $arr_imgids);

    $sql = "SELECT img_link, img_thumb 
            FROM mycars_gallery WHERE car_id = :carid AND id IN({$in_sql});"; 

    $params = array_merge(
        array(":carid" => $car_id), 
        array_combine(explode(',', $in_sql), $arr_imgids)
    );

    //DB processing happens in Database class(100% working)
    $dbconn = new Database;     
    $rows = $dbconn->dbProcess($sql, $params); //doesnt run
}
于 2013-08-22T02:12:36.187 回答