Rumah >pangkalan data >tutorial mysql >Bagaimana Menggunakan Subquery WHERE...IN dengan Pembina Pertanyaan Doctrine 2?
Contoh ini menunjukkan mendapatkan semula item pesanan yang dikaitkan dengan pesanan yang mengandungi item tertentu, mencerminkan kefungsian pertanyaan SQL:
Pertanyaan SQL Setara:
<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>
Pelaksanaan Pembina Pertanyaan Doktrin 2:
<code class="language-php"><?php // Access Doctrine's ExpressionBuilder $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', $em->createQueryBuilder() ->select('o2.id') ->from('Order', 'o2') ->join('Item', 'i2', \Doctrine\ORM\Query\Expr\Join::WITH, $expr->andX( $expr->eq('i2.order', 'o2'), $expr->eq('i2.id', '?1') ) ) ->getDQL() ) ) ->andWhere($expr->neq('i.id', '?2')) ->orderBy('o.orderdate', 'DESC') ->setParameter(1, 5) ->setParameter(2, 5);</code>
Pertimbangan Penting:
LIMIT
dalam subkueri.IN
secara konvensional mengharapkan tatasusunan, klausa itu juga menampung subkueri.id
disyorkan untuk ketekalan, walaupun tidak diperlukan sepenuhnya.Atas ialah kandungan terperinci Bagaimana Menggunakan Subquery WHERE...IN dengan Pembina Pertanyaan Doctrine 2?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!