学说2 - 来自存储过程的水合作用

时间:2013-08-12 14:57:23

标签: postgresql symfony stored-procedures doctrine-orm doctrine-query

我对存储过程(pgsql)没什么问题。 在返回此过程时,数组返回具有特殊结构,以这种方式对我无法使用。

我尝试了许多不同的方式来调用SP或Hydratation方法但总是返回同样的类型。

你能帮我解决这个问题吗?

我的规格:我想要一个数组作为返回(只需要值),但是SP返回一个数组数组,其中一行是结果,如下所示(var_dumped):

array (size=3)
  0 => 
    array (size=1)
      'get_structure_utilisateur' => int 2
  1 => 
    array (size=1)
      'get_structure_utilisateur' => int 1
  2 => 
    array (size=1)
      'get_structure_utilisateur' => int 10

我想要像:

array (size=3)
    0 => 2
    1 => 1
    2 => 10

我尝试这个或这个,结果相同或差别很小:

$query = $this->getEntityManager()
    ->getConnection()
    ->query('select admin.get_structure_utilisateur(3, 1)')
    ->fetchAll();

$sql = "select admin.get_structure_utilisateur(:utilisateurId, :clientId)";
$rsm = new ResultSetMapping;
$rsm->addScalarResult('get_structure_utilisateur', 'structures');
$query = $this->getEntityManager()->createNativeQuery($sql, $rsm)
    ->setParameter('clientId', 1)
    ->setParameter('utilisateurId', 3);
$query->getResult(Query::HYDRATE_SCALAR);// I Try some other hydratation method

由于

1 个答案:

答案 0 :(得分:3)

尝试使用fetchColumn

    $em = $this->getEntityManager();
    $db = $em->getConnection();
    $stmt = $db->prepare('select admin.get_structure_utilisateur(:utilisateurId, :clientId)');
    $stmt->bindValue('clientId', 1);
    $stmt->bindValue('utilisateurId', 3);
    $stmt->execute();
    while (($row = $stmt->fetchColumn()) !== false) {
        print $row;
    }