Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Memilih Data daripada Berbilang Jadual dengan Lajur Yang Sama dan Kabur?

Bagaimana untuk Memilih Data daripada Berbilang Jadual dengan Lajur Yang Sama dan Kabur?

Barbara Streisand
Barbara Streisandasal
2024-12-29 15:52:15144semak imbas

How to Select Data from Multiple Tables with Identical, Ambiguous Columns?

Menyertai Jadual dengan Lajur Kabur: Memilih Data daripada Jadual Berganda Replika

Cabaran anda untuk mendapatkan data daripada berbilang jadual dengan struktur yang sama tetapi dipisahkan untuk penyetempatan menimbulkan kesamaran apabila menentukan lajur dalam klausa WHERE. MySQL tidak dapat menentukan jadual mana yang hendak dirujuk apabila membandingkan lajur yang tidak jelas, seperti 'genre' dalam pertanyaan anda.

Penyelesaian: Gunakan Operator UNION

Untuk menyelesaikan kekaburan ini , anda boleh menggunakan operator UNION. UNION menggabungkan hasil dua atau lebih pernyataan SELECT, mencipta jadual maya dengan berkesan dengan gabungan semua baris daripada jadual individu.

Pertanyaan Diubah Suai:

(SELECT * FROM us_music WHERE `genre` = 'punk')
UNION
(SELECT * FROM de_music WHERE `genre` = 'punk')

Penjelasan:

Pertanyaan yang diubah suai ini memisahkan pernyataan SELECT untuk setiap jadual yang terlibat. Setiap subkueri mendapatkan semula data daripada jadual tertentu, memastikan tiada kesamaran dalam rujukan lajur 'genre'. Operator UNION kemudiannya menggabungkan keputusan ke dalam set hasil tunggal, memberikan anda data yang dikehendaki daripada berbilang jadual.

Atas ialah kandungan terperinci Bagaimana untuk Memilih Data daripada Berbilang Jadual dengan Lajur Yang Sama dan Kabur?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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