1

我正在尝试更新 Note Entity 中的字段“note”,该字段与“ElementModule”和“Inscription”具有 ManyToOne(双向)关系,实体“Inscription”与“Etudiant”实体具有 ManyToOne 关系

我试过这个 DQL 查询:

$query = $this->_em->createQuery('update UaePortailBundle:Note u JOIN u.inscription i JOIN u.elementmodule e join i.etudiant et set u.note = ?3
                                                where et.id = ?1 and e.id = ?2 ');
    $query->setParameter(1, $etudiant);
    $query->setParameter(2, $element);
    $query->setParameter(3, $note);
    $resultat = $query->execute();

我得到这个错误

[Syntax Error] line 0, col 50: Error: Expected Doctrine\ORM\Query\Lexer::T_EQUALS, got 'i'
4

2 回答 2

2

LEFT JOIN,或特别是 JOIN 仅在 MySQL 的 UPDATE 语句中受支持。DQL 抽象了普通 ansi sql 的一个子集,所以这是不可能的。尝试使用子选择或 IDENTITY(您必须使用最新版本的 Doctrine 2.2.2):

createQuery('update UaePortailBundle:Note u set u.note = ?3
             where IDNETITY(u.inscription) = ?1 and IDENTITY(u.elementmodule) = ?2 ');
于 2012-05-24T20:43:25.787 回答
1

在搜索并尝试使用教义 dql 找到解决方案后,我找不到它,所以我使用直接 sql 查询来更新数据库。

     $stmt = $this->getEntityManager()
               ->getConnection()
               ->prepare("update note set note = :note where `etudiant_id` like :etudiant_id and `elementmodule_id` like :elementmodule_id");
                $stmt->bindValue('etudiant_id',$etudiant);
                $stmt->bindValue('elementmodule_id' ,$element );
                $stmt->bindValue('note', $note);
                $stmt->execute();
于 2012-05-25T09:26:00.657 回答