Rumah > pangkalan data > tutorial mysql > Bagaimana Menggunakan Subquery WHERE...IN dengan Pembina Pertanyaan Doctrine 2?

Bagaimana Menggunakan Subquery WHERE...IN dengan Pembina Pertanyaan Doctrine 2?

Barbara Streisand
Lepaskan: 2025-01-13 21:54:47
asal
358 orang telah melayarinya

How to Use a WHERE...IN Subquery with Doctrine 2's Query Builder?

Menggunakan WHERE...IN Subqueries dalam Doktrin 2's Query Builder

Contoh ini menunjukkan mendapatkan semula item pesanan yang dikaitkan dengan pesanan yang mengandungi item tertentu, mencerminkan kefungsian pertanyaan SQL:

Pertanyaan SQL Setara:

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;
Salin selepas log masuk

Pelaksanaan Pembina Pertanyaan Doktrin 2:

<?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);
Salin selepas log masuk

Pertimbangan Penting:

  • Penghadan prestasi mungkin timbul dengan pengendalian Doktrin 2 terhadap fasal LIMIT dalam subkueri.
  • Walaupun klausa IN secara konvensional mengharapkan tatasusunan, klausa itu juga menampung subkueri.
  • Menggunakan semula parameter yang sama untuk kedua-dua kejadian 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!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan