pdo参数不绑定

时间:2014-09-26 23:29:36

标签: php mysql codeigniter debugging pdo

我正在尝试将一个参数绑定到我的查询中,它没有绑定一些参数。

已发布数组

Array
(
    [action] => add_category
    [fk_user_account_type_id] => Array
        (
            [0] => 1
            [1] => 2
            [2] => 5
            [3] => 6
            [4] => 7
            [5] => 8
            [6] => 9
        )

    [cat_name] => Special Deals
    [parent_cat] => 0
    [cat_status] => Active
    [page_content] => 

this is test
)

$cat_name = $postArray['cat_name'];
$cat_status = $postArray['cat_status'];
$parent_id = $postArray['parent_cat'];
$cat_description    =   $postArray['page_content'];

$sql = "INSERT INTO tbl_category SET `category_title` = :cat_name  , `category_alias` = :category_alias , `category_status`= :cat_status, `category_parent_id` = :parent_id, "
                . "category_description =   :cat_description";
        $statement = $this->db->conn_id->prepare($sql);
        $statement->bindParam(':cat_name', $cat_name, PDO::PARAM_STR);
        $statement->bindParam(':cat_status', $cat_status, PDO::PARAM_STR);
        $statement->bindParam(':category_alias', $category_alias, PDO::PARAM_STR);
        $statement->bindParam(':parent_id', $parent_id, PDO::PARAM_INT);
        $statement->bindParam(':cat_description',$cat_description, PDO::PARAM_STR);

当我做的时候

 echo $this->parms($sql,$postArray); exit // for debugging;

它向我展示了像

这样的查询
INSERT INTO tbl_category SET `category_title` = 'Special Deals'  , `category_alias` = 'special_deals' , `category_status`= 'Active', `category_parent_id` = :parent_id, category_description =   :cat_description

1 个答案:

答案 0 :(得分:0)

BindParam通过引用传递,因此它需要一个值而您没有,请将其替换为bindValue

$statement->bindValue(':cat_name', $cat_name, PDO::PARAM_STR);
    $statement->bindValue(':cat_status', $cat_status, PDO::PARAM_STR);
    $statement->bindValue(':category_alias', $category_alias, PDO::PARAM_STR);
    $statement->bindValue(':parent_id', $parent_id, PDO::PARAM_INT);
    $statement->bindValue(':cat_description',$cat_description, PDO::PARAM_STR);