Heim >Datenbank >MySQL-Tutorial >Wie führe ich eine WHERE…IN-Unterabfrage mit dem Query Builder von Doctrine 2 aus?

Wie führe ich eine WHERE…IN-Unterabfrage mit dem Query Builder von Doctrine 2 aus?

Linda Hamilton
Linda HamiltonOriginal
2025-01-13 22:51:46222Durchsuche

How to Execute a WHERE…IN Subquery Using Doctrine 2's Query Builder?

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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn