Doctrine - Symfony查询错误

时间:2017-03-22 13:25:26

标签: php symfony doctrine-orm

我确实有错误而且我不知道如何修复

$query = $entityManager->createQuery("UPDATE AppBundle:ChangeAPI SET `key`='asd123' WHERE `id` = 1");
$query->execute();

我的AppBundle:ChangeAPI

/**
 * @ORM\Entity
 * @ORM\Table(name="api")
 */
 class ChangeAPI
 {
     /**
      * @ORM\Column(type="integer")
      * @ORM\Id
      * @ORM\GeneratedValue(strategy="AUTO")
      */
     protected $id;

     /**
      * The date on which the shipment has been created
      *
      * @ORM\Column(type="string", name="key")
      */
     protected $key;

     /** Creates a new standard ride */
     function __construct()
     {
     }
 }

这是我的错误结果:

[Syntax Error] line 0, col 31: Error: Expected Doctrine\ORM\Query\Lexer::T_SET, got '`'
QueryException: [Syntax Error] line 0, col 31: Error: Expected Doctrine\ORM\Query\Lexer::T_SET, got '`'
QueryException: UPDATE AppBundle:ChangeAPI SET `key`='asd123' WHERE `id` = 1 

有人能帮帮我吗?感谢。

4 个答案:

答案 0 :(得分:6)

为什么不使用查询构建器:

$entityManager->createQueryBuilder()
    ->update('AppBundle:ChangeAPI', 'c')
    ->set('c.key', ':key')
    ->where('c.id = :id')
    ->setParameter('key', 'asd123')
    ->setParameter('id', 1)
    ->getQuery()
    ->execute();

完整参考http://docs.doctrine-project.org/projects/doctrine-orm/en/latest/reference/query-builder.html

答案 1 :(得分:2)

尝试使用别名:

$query = $entityManager->createQuery("UPDATE AppBundle:ChangeAPI c SET c.key='asd123' WHERE c.id = 1");
$query->execute();

希望这个帮助

答案 2 :(得分:1)

它不是MySQL查询它的DQL查询,因此,不要使用"`"细胞名称的字符。

$query = $entityManager->createQuery("UPDATE AppBundle:ChangeAPI SET key='asd123' WHERE id = 1");

答案 3 :(得分:0)

我猜你可以通过Doctrine为此创建一个查询。另一种方法是在普通的控制器方法中更改它们。

在您的控制器中:

/**
 * @Route("/edit/{id}"), name="app_edit_API")
 * @param ChangeAPI
 */
public function editAPIAction(ChangeAPI $changeAPI)
{
     $changeAPI->setKey('asd123');
     $this->getDoctrine()->getManager()->flush();
}

您使用的是表格还是这个命令?如果是这样,那么Palethorn上面的答案是一个更好的选择。