Apabila menggunakan ThinkPHP untuk operasi pangkalan data, selalunya perlu melakukan pertanyaan berbilang keadaan jadual silang. Dalam kes ini, kita perlu menggunakan pembina pertanyaan (Pembina Pertanyaan) yang disediakan oleh ThinkPHP untuk membina pernyataan pertanyaan. Artikel ini akan memperkenalkan cara menggunakan pembina pertanyaan ThinkPHP untuk melaksanakan pertanyaan berbilang keadaan jadual silang.
1. Pertanyaan jadual induk-hamba
Apabila melakukan pertanyaan jadual silang, kita perlu terlebih dahulu menentukan jadual mana jadual induk dan jadual mana jadual hamba. Jadual induk ialah jadual yang ingin kita tanya, dan jadual hamba ialah jadual yang ingin kita tanya. Sebagai contoh, kita mempunyai dua jadual, satu jadual pengguna (pengguna) dan satu lagi jadual pesanan (pesanan). Jika kita ingin menanyakan semua maklumat pesanan pengguna ini, maka jadual pengguna adalah jadual utama dan meja pesanan ialah meja hamba.
Anda boleh menggunakan pertanyaan sertai untuk menanyakan jadual induk-hamba menggunakan ThinkPHP Terdapat empat jenis pertanyaan gabungan: kiri, kanan, dalam dan penuh. Sila fahami sendiri perbezaan antara empat pertanyaan penyertaan ini.
Kod sampel:
$users = Db::table('users') ->alias('u') ->join('orders o', 'o.user_id = u.id', 'left') ->select();
Dalam kod sampel di atas, kami menggunakan kaedah jadual kelas Db untuk menentukan jadual utama, kaedah alias untuk menetapkan alias jadual, dan kaedah gabungan untuk Melaksanakan pertanyaan berkaitan. Antaranya, parameter pertama ialah nama jadual jadual hamba, parameter kedua ialah keadaan persatuan kedua-dua jadual, dan parameter ketiga ialah jenis gabungan.
2. Pertanyaan merentas berbilang jadual hamba
Apabila melakukan pertanyaan silang jadual, kadangkala anda perlu mengaitkan berbilang jadual hamba Dalam kes ini, anda boleh menggunakan berbilang kaedah gabungan untuk mengaitkan.
Kod sampel:
$users = Db::table('users') ->alias('u') ->join('orders o', 'o.user_id = u.id', 'left') ->join('order_items oi', 'oi.order_id = o.id', 'left') ->select();
Dalam kod sampel di atas, kami menggunakan kaedah gabungan dua kali, kali pertama untuk mengaitkan jadual pesanan dan kali kedua untuk mengaitkan jadual item pesanan . Dengan cara ini, kami boleh menanyakan semua maklumat pesanan pengguna dan semua maklumat item baris dalam setiap pesanan.
3. Pertanyaan berbilang syarat
Apabila melakukan pertanyaan data, kadangkala lebih daripada satu data perlu disoal dan berbilang syarat perlu digunakan untuk menentukan data yang hendak disoal. Pada masa ini, anda boleh menggunakan kaedah where untuk menetapkan berbilang syarat pertanyaan. Katakan kami ingin menanyakan maklumat semua pengguna dalam jadual pengguna yang berumur lebih daripada 25 tahun dan jantinanya adalah lelaki Kami boleh menggunakan kod berikut:
Kod contoh:
$users = Db::table('users') ->where('age', '>', 25) ->where('gender', 'male') ->select();
Dalam kod sampel di atas, Kami menggunakan kaedah where dua kali untuk menetapkan syarat pertanyaan. Parameter pertama ialah nama medan keadaan pertanyaan, parameter kedua ialah pengendali perbandingan keadaan pertanyaan, dan parameter ketiga ialah nilai keadaan pertanyaan.
4. Pertanyaan berbilang keadaan jadual silang
Apabila melakukan pertanyaan jadual silang, kami boleh menggabungkan kaedah di mana dan kaedah gabungan untuk melaksanakan pertanyaan berbilang keadaan jadual. Sebagai contoh, dalam contoh di atas, kami ingin menanyakan semua maklumat pesanan semua pengguna yang berumur lebih daripada 25 tahun dan jantina mereka adalah lelaki dalam jadual pengguna, kami boleh menggunakan kod berikut:
Kod sampel :
$users = Db::table('users') ->alias('u') ->join('orders o', 'o.user_id = u.id', 'left') ->where('u.age', '>', 25) ->where('u.gender', 'male') ->select();
Dalam kod contoh di atas, kami menambah alias jadual yang mempunyai syarat pertanyaan di hadapan keadaan pertanyaan. Dengan cara ini, pertanyaan berbilang keadaan jadual silang boleh dilaksanakan.
Apabila menggunakan ThinkPHP untuk pertanyaan berbilang keadaan jadual silang, anda perlu memberi perhatian kepada perkara berikut:
Atas ialah kandungan terperinci Penjelasan terperinci tentang cara thinkphp melaksanakan pertanyaan berbilang keadaan jadual silang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!