Penggunaan EXISTS dalam MYSQL, dengan contoh kod
Dalam pangkalan data MYSQL, EXISTS ialah pengendali yang sangat berguna, digunakan untuk menentukan sama ada subkueri mengembalikan sekurang-kurangnya satu baris data. Ia biasanya digunakan dengan klausa WHERE untuk menapis data yang memenuhi syarat berdasarkan hasil subkueri.
Anda perlu memberi perhatian kepada perkara berikut apabila menggunakan EXISTS:
Di bawah ini kami menggunakan beberapa contoh kod khusus untuk menggambarkan penggunaan EXISTS.
Katakan kita mempunyai dua jadual: jadual produk (produk) dan jadual pesanan (pesanan).
Struktur jadual produk adalah seperti berikut:
CREATE TABLE products ( id INT, name VARCHAR(50), price FLOAT );
Struktur jadual pesanan adalah seperti berikut:
CREATE TABLE orders ( id INT, product_id INT, quantity INT );
Sekarang, kami ingin mengetahui semua produk dengan pesanan. Kita boleh menggunakan subkueri EXISTS untuk mencapai matlamat ini.
SELECT * FROM products p WHERE EXISTS ( SELECT 1 FROM orders o WHERE o.product_id = p.id );
Dalam contoh di atas, subkueri SELECT 1 FROM orders o WHERE o.product_id = p.id
将返回一个结果集,这个结果集至少包含一行数据,表示有订单与当前商品相关联。在外层查询中,我们使用了EXISTS条件,如果子查询返回至少一行数据,则此条记录会被返回。
我们也可以使用EXISTS与其他条件结合来进一步筛选数据。比如,我们想找出所有价格低于100的有订单的商品。
SELECT * FROM products p WHERE price < 100 AND EXISTS ( SELECT 1 FROM orders o WHERE o.product_id = p.id );
上述代码中,我们在外层查询的WHERE子句中增加了price
rrreee
Dalam kod di atas, kami menambah syaratAtas ialah kandungan terperinci Menggunakan fungsi EXISTS dalam MYSQL. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!