如何使用Doctrine2和MySQL执行存储过程

una*_*dan 15 mysql stored-procedures symfony doctrine-orm

我在Symfony2应用程序中工作,我需要使用存储过程来执行一些高性能的过程.

有没有办法使用Doctrine2执行(和管理参数)MySQL存储过程?

解:

$em = $this->getDoctrine()->getEntityManager();
$qb = $em->createNativeQuery(
        'CALL USR_P_UserRegistration (' .
            ':iduser, :name, :surname, :birthday, :idlang, :idregistry' .
        ')',
        new ResultSetMapping()
    );
$qb->setParameters(
    array(
        'iduser' => $c->getIduser(),
        'name' => $c->getName(),
        'surname' => $c->getSurname(),
        'birthday' => $c->getBirthday(),
        'idlang' => $c->getIdlang(),
        'idregistry' => $c->getIdregistry()
    ));
$qb->execute();
$em->flush();
Run Code Online (Sandbox Code Playgroud)

a.a*_*dad 7

您可以使用Native SQL,甚至可以使用存储过程进行数据检索.

doc Native sql

或者您可以查看此链接

如何使用Symfony和Doctrine的存储过程