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!