我的变量有两种类型


my variable has 2 types

我需要你的帮助,因为我遇到了一个不常见的问题:在我的代码中,我有一个第一个函数,在该函数中,我用PDO处理一个请求,PDO返回一个数组,该数组的结果在一个名为"result"的变量中。当我对这个变量执行var_dump()时,它会显示:

array(4) { ["id_offre_var"]=> string(4) "7061" ["id_offre"]=> string(4) "3216" ["prix"]=> string(5) "29.90" ["prix_public"]=> string(5) "69.00" }

所以,我有一个数组,没关系。

然后,我调用一个名为hydrate()的函数,在其中放入变量"result"。但是,在这个函数中,当我对这个参数(我以前的变量"result")执行var_dump()时,它向我显示:

array(4) { ["id_offre_var"]=> string(4) "7061" ["id_offre"]=> string(4) "3216" ["prix"]=> string(5) "29.90" ["prix_public"]=> string(5) "69.00" } bool(false)

我的变量现在是一个数组和一个布尔值!很明显,这给我的下一步提出了问题。

我的第一个功能:

public function getVarianteForNewsletter($idOffre)
{
    $sql = "SELECT id_offre_var, id_offre, prix, prix_public FROM apm_offres_variante
          WHERE id_offre = :offre
          ORDER BY prix
          LIMIT 0,1";
    $stmt = $this->_dal->prepare($sql);
    $stmt->bindValue(":offre", $idOffre, PDO::PARAM_INT);
    $stmt->execute();
    $result = $stmt->fetch(PDO::FETCH_ASSOC);
    var_dump($result);
    $Object = new OffreVariante();
    $this->hydrate($Object, $result);
    return $Object;
}

然后,我的函数hydrate():

protected function hydrate($Object, $params)
{
    var_dump($params);
    foreach ($params as $key=>$param)
    {
        $var = array_search($key, $this->_varsColsName);
        if ($var != false)
        {
            //if $var is a foreign key to another object
            if (array_key_exists($var, $this->_foreignKeys))
            {
                $fk = $this->_foreignKeys[$var];
                $daoName = "DAO".ucfirst($fk);
                $dao = new $daoName($this->_dal);
                $param = $dao->getById($param);
            }
            $setter = "set".ucfirst($var);
            $Object->$setter($param);
        }
    }
}

最后,问题是由foreach()中的$key=>$item引起的。如果我有这个,它就不起作用:

foreach ($params as $key=>$param) 

但如果我有,它工作:

foreach ($params as $param)

我不知道为什么,但我将尝试使用一个简单的FOR循环。谢谢你的帮助。