Cómo realizar uniones izquierdas en Doctrine
En tu función getHistory(), estás intentando recuperar el historial crediticio de un usuario . Sin embargo, la sintaxis inicial en su cláusula de unión resultó en un error.
Para realizar una unión izquierda en Doctrine, puede usar la siguiente sintaxis:
$qb
->select('a', 'u')
->from('Credit\Entity\UserCreditHistory', 'a')
->leftJoin('a.user', 'u')
->where('u = :user')
->setParameter('user', $users)
->orderBy('a.created_at', 'DESC');
Aquí, a representa el alias de la entidad UserCreditHistory y u representa el alias de la entidad de usuario unida. Al utilizar el método leftJoin(), estás especificando que deseas incluir filas de la tabla Usuario que no coinciden en la tabla UserCreditHistory.
Alternativamente, si no tienes una asociación entre los dos entidades, puede utilizar la siguiente sintaxis:
$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');
````
Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.
Copyright© 2022 湘ICP备2022001581号-3