Nutzung des Abfrage-Generators von Doctrine 2 für WHERE…IN-Unterabfragen
Diese Anleitung zeigt, wie Sie eine Doctrine 2-Abfrage erstellen, um eindeutige Bestellartikel auszuwählen, die einen bestimmten Artikel enthalten. Die entsprechende SQL-Abfrage lautet:
<code class="language-sql">SELECT DISTINCT i.id, i.name, order.name FROM items i JOIN orders o ON i.order_id=o.id WHERE o.id IN ( SELECT o2.id FROM orders o2 JOIN items i2 ON i2.order_id=o2.id AND i2.id=5 ) AND i.id != 5 ORDER BY o.orderdate DESC LIMIT 10</code>
So replizieren Sie dies mit dem Abfrage-Builder von Doctrine 2:
<code class="language-php">/** @var Doctrine\ORM\EntityManager $em */ $expr = $em->getExpressionBuilder(); $qb = $em->createQueryBuilder(); $qb->select(array('DISTINCT i.id', 'i.name', 'o.name')) ->from('Item', 'i') ->join('i.order', 'o') ->where( $expr->in( 'o.id', $qb->createSubquery() ->select('o2.id') ->from('Order', 'o2') ->join('o2.items', 'i2') // Assuming a proper relationship ->where($expr->eq('i2.id', '?1')) ->getDQL() ) ) ->andWhere($expr->neq('i.id', '?2')) ->orderBy('o.orderdate', 'DESC') ->setMaxResults(10) // Use setMaxResults for LIMIT ->setParameter(1, 5) ->setParameter(2, 5); $query = $qb->getQuery(); $results = $query->getResult();</code>
Dieser verbesserte Abfrage-Builder-Code nutzt eine Unterabfrage effizienter. Es wird eine korrekt definierte Beziehung zwischen den Entitäten Order
und Item
vorausgesetzt. setMaxResults(10)
wird verwendet, anstatt sich auf mögliche Unterabfragebeschränkungen zu verlassen. Denken Sie daran, dass die Entitäten Item
und Order
in Ihren Doctrine 2-Zuordnungen vorhanden sein müssen. Es wird weiterhin empfohlen, gründliche Tests durchzuführen, um potenzielle Grenzfälle zu bewältigen.
Das obige ist der detaillierte Inhalt vonWie führe ich eine WHERE…IN-Unterabfrage mit dem Query Builder von Doctrine 2 aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!