」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何在信用記錄檢索中實現左連接?

如何在信用記錄檢索中實現左連接?

發佈於2024-11-08
瀏覽:430

How to Implement Left Joins in Doctrine for Credit History Retrieval?

How to Perform Left Joins in Doctrine

在函數 getHistory() 中,您嘗試擷取使用者的信用歷史記錄。但是,連接子句中的初始語法導致了錯誤。

要在 Doctrine 中執行左連接,可以使用以下語法:

$qb
    ->select('a', 'u')
    ->from('Credit\Entity\UserCreditHistory', 'a')
    ->leftJoin('a.user', 'u')
    ->where('u = :user')
    ->setParameter('user', $users)
    ->orderBy('a.created_at', 'DESC');

這裡,a 表示 UserCreditHistory 實體的別名,u 表示加入的 User 實體的別名。透過使用 leftJoin() 方法,您可以指定要包含 User 表中與 UserCreditHistory 表中不符的行。

或者,如果兩者之間沒有關聯實體,您可以使用以下語法:

$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');
````
最新教學 更多>

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3