


PHP menanyakan kandungan dua jadual pada masa yang sama
Apabila membangunkan tapak web atau aplikasi, kita selalunya perlu mendapatkan data daripada jadual pangkalan data yang berbeza. Dalam PHP, kita boleh menggunakan pernyataan SQL untuk mendapatkan semula data daripada satu jadual, tetapi jika kita perlu mendapatkan data daripada berbilang jadual pada masa yang sama, kita perlu menulis pernyataan pertanyaan yang kompleks. Dalam artikel ini, kita akan belajar bagaimana untuk menanyakan kandungan dua jadual secara serentak menggunakan PHP.
1. Sertai dua jadual
Apabila menggunakan pernyataan pertanyaan SQL untuk mendapatkan data daripada dua jadual, kita perlu menggunakan fungsi sambungan (JOIN). Gabungan memadankan data dalam dua jadual, menghasilkan set hasil yang mengandungi semua data yang sepadan dalam kedua-dua jadual. Dalam PHP, kita boleh menggunakan fungsi mysqli untuk melakukan pertanyaan sambungan.
Berikut ialah contoh kod untuk mendapatkan data daripada dua jadual:
$mysqli = new mysqli("localhost", "username", "password", "mydatabase"); $query = "SELECT * FROM table1 JOIN table2 ON table1.id = table2.id"; $result = $mysqli->query($query); if ($result->num_rows > 0) { while($row = $result->fetch_assoc()) { echo "Name: " . $row["name"]. " - Email: " . $row["email"]. " - Phone: " . $row["phone"]. "<br>"; } } else { echo "0 results"; } $mysqli->close();
Dalam kod di atas, kami menanyakan dua jadual bernama table1 dan table2. Dengan menyatakan pernyataan ON, kami menggabungkan dua jadual bersama-sama. Dengan menggunakan SELECT * kita boleh mendapatkan semula semua medan daripada kedua-dua jadual.
2. Gunakan sambung kiri
Jika kita perlu mendapatkan data daripada dua jadual, dan data dalam satu jadual mungkin tidak sepadan dengan jadual yang lain, kita perlu menggunakan sambung kiri. Gabungan kiri boleh mendapatkan set hasil dengan baris yang sepadan dan tidak sepadan. Dalam PHP, kita boleh melakukan gabungan kiri menggunakan kata kunci LEFT JOIN.
Berikut ialah contoh kod untuk mendapatkan data menggunakan left join:
$mysqli = new mysqli("localhost", "username", "password", "mydatabase"); $query = "SELECT table1.name, table2.email FROM table1 LEFT JOIN table2 ON table1.id = table2.id"; $result = $mysqli->query($query); if ($result->num_rows > 0) { while($row = $result->fetch_assoc()) { echo "Name: " . $row["name"]. " - Email: " . $row["email"]. "<br>"; } } else { echo "0 results"; } $mysqli->close();
Dalam kod di atas, kami telah menggunakan left join untuk mendapatkan semula data daripada dua jadual. Kami menentukan medan untuk dipilih daripada setiap jadual, dan keadaan HIDUP yang digunakan dalam pernyataan LEFT JOIN. Set hasil akan merangkumi semua baris dalam jadual1, serta baris yang sepadan dengan baris dalam jadual2. Jika tiada baris yang sepadan dalam jadual2, NULL akan menggantikan nilai dalam set hasil.
3. Gunakan alias
Apabila mendapatkan semula data daripada berbilang jadual, kami mungkin menghadapi masalah medan dengan nama yang sama dalam berbilang jadual. Untuk menyelesaikan masalah ini kita boleh menggunakan alias. Alias ialah nama lain yang digunakan untuk mengenal pasti jadual atau medan. Dalam PHP, kita boleh menggunakan kata kunci AS untuk menentukan alias untuk jadual atau medan.
Berikut ialah contoh kod menggunakan alias:
$mysqli = new mysqli("localhost", "username", "password", "mydatabase"); $query = "SELECT table1.name AS customer_name, table2.email AS customer_email FROM table1 JOIN table2 ON table1.id = table2.id"; $result = $mysqli->query($query); if ($result->num_rows > 0) { while($row = $result->fetch_assoc()) { echo "Name: " . $row["customer_name"]. " - Email: " . $row["customer_email"]. "<br>"; } } else { echo "0 results"; } $mysqli->close();
Dalam kod di atas, kami telah menentukan alias untuk medan dalam setiap jadual menggunakan kata kunci AS. Dengan menggunakan alias kita boleh mengelakkan konflik yang disebabkan oleh medan dengan nama yang sama dalam dua jadual.
Kesimpulan
Dalam artikel ini, kami membincangkan cara untuk menanyakan kandungan dua jadual secara serentak menggunakan PHP. Kami menggunakan fungsi join dan left join, serta sintaks alias. Dengan menggunakan teknik ini, kami boleh mendapatkan semula data daripada berbilang jadual dengan mudah dan menggabungkannya ke dalam set hasil tunggal. Sama ada kami sedang membangunkan tapak web atau aplikasi, teknologi ini sangat berguna untuk mendapatkan dan mengatur data.
Atas ialah kandungan terperinci PHP menanyakan kandungan dua jadual pada masa yang sama. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Artikel ini meneroka deduplikasi array PHP yang cekap. Ia membandingkan fungsi terbina dalam seperti array_unique () dengan pendekatan hashmap tersuai, menonjolkan prestasi perdagangan berdasarkan saiz array dan jenis data. Kaedah optimum bergantung pada profili

Artikel ini menganalisis PHP Array Deduplication, menonjolkan kemunculan prestasi pendekatan naif (O (N²)). Ia meneroka alternatif yang cekap menggunakan array_unique () dengan fungsi tersuai, splobjectstorage, dan pelaksanaan hashset, mencapai

Artikel ini meneroka deduplikasi PHP Array menggunakan keunikan utama. Walaupun bukan kaedah penyingkiran pendua langsung, memanfaatkan keunikan utama membolehkan membuat array baru dengan nilai yang unik dengan nilai pemetaan ke kekunci, menimpa duplikat. AP ini

Butiran artikel ini melaksanakan beratur mesej dalam PHP menggunakan RabbitMQ dan Redis. Ia membandingkan seni bina mereka (AMQP vs dalam memori), ciri-ciri, dan mekanisme kebolehpercayaan (pengesahan, urus niaga, kegigihan). Amalan terbaik untuk reka bentuk, kesilapan

Artikel ini mengkaji piawaian pengekodan PHP semasa dan amalan terbaik, memberi tumpuan kepada cadangan PSR (PSR-1, PSR-2, PSR-4, PSR-12). Ia menekankan peningkatan kebolehbacaan dan kebolehkerjaan kod melalui gaya yang konsisten, penamaan bermakna, dan EFF

Artikel ini meneroka mengoptimumkan deduplikasi array PHP untuk dataset yang besar. Ia mengkaji teknik-teknik seperti array_unique (), array_flip (), splobjectstorage, dan pra-sorting, membandingkan kecekapan mereka. Untuk dataset besar -besaran, ia mencadangkan pemotongan, pangkalan data

Butiran artikel ini memasang dan menyelesaikan masalah PHP, memberi tumpuan kepada PECL. Ia meliputi langkah pemasangan (mencari, memuat turun/menyusun, membolehkan, memulakan semula pelayan), teknik penyelesaian masalah (memeriksa log, mengesahkan pemasangan,

Artikel ini menerangkan API Refleksi PHP, membolehkan pemeriksaan runtime dan manipulasi kelas, kaedah, dan sifat. IT memperincikan kes penggunaan biasa (penjanaan dokumentasi, ORM, suntikan pergantungan) dan memberi amaran terhadap prestasi overhea
