如何在 Doctrine 中執行左連線
在函數 getHistory() 中,您嘗試擷取使用者的信用歷史記錄。但是,join 子句中的初始語法導致了錯誤。
要在 Doctrine 中執行左聯接,可以使用以下語法:
<code class="php">$qb ->select('a', 'u') ->from('Credit\Entity\UserCreditHistory', 'a') ->leftJoin('a.user', 'u') ->where('u = :user') ->setParameter('user', $users) ->orderBy('a.created_at', 'DESC');</code>
這裡,a 代表別名對於 UserCreditHistory 實體,u 表示已加入的 User 實體的別名。透過使用 leftJoin() 方法,您指定要包含 User 表中與 UserCreditHistory 表中不符的行。
或者,如果兩者之間沒有關聯實體,您可以使用以下語法:
<code class="php">$qb ->select('a', 'u') ->from('Credit\Entity\UserCreditHistory', 'a') ->leftJoin( 'User\Entity\User', 'u', \Doctrine\ORM\Query\Expr\Join::WITH, 'a.user = u.id' ) ->where('u = :user') ->setParameter('user', $users) ->orderBy('a.created_at', 'DESC'); ```` </code>
以上是如何在信用記錄檢索中實現左連接?的詳細內容。更多資訊請關注PHP中文網其他相關文章!