Dalam Laravel, adalah perkara biasa untuk mentakrifkan jadual sepadan model menggunakan sifat jadual, seperti:
class User extends Model { protected $table = 'users'; }
Walau bagaimanapun, daripada memetakan terus ke jadual, kita boleh menggunakan subkueri. Teknik ini membolehkan kami merangkum pertanyaan kompleks dalam lapisan aplikasi, sama seperti mencipta paparan pangkalan data, tetapi dengan fleksibiliti tambahan operasi Eloquent.
Sebagai contoh, pertimbangkan jadual pengguna yang menyimpan maklumat tentang kedua-dua pentadbir dan pengguna biasa. Kita boleh mencipta model AdminUser menggunakan subquery:
class AdminUser { public function getTable(): string|\Illuminate\Contracts\Database\Query\Expression { $sql = User::query() ->select('id', 'name') ->where('admin_user', true) ->toRawSql(); return DB::raw(sprintf('(%s) as admin_users', $sql)); } }
Model ini menarik data daripada subkueri (pilih id, nama daripada pengguna dengan admin_user = 1), membolehkan anda menanyakannya sama seperti model standard:
AdminUser::query()->get();
atau
AdminUser::query()->first();
Walau bagaimanapun, ambil perhatian bahawa pertanyaan tertentu, seperti find(1), tidak akan berfungsi secara langsung:
AdminUser::query()->find(1);
Untuk mengatasi perkara ini, anda boleh menggunakan keadaan where digabungkan dengan first():
AdminUser::query()->where('id', 1)->first();
Contoh yang diberikan ialah ilustrasi yang jelas tentang cara kita boleh menstruktur logik dalam model. Walau bagaimanapun, pendekatan ini boleh ditingkatkan dan disesuaikan untuk menampung senario yang lebih kompleks. Dengan memanfaatkan struktur sedemikian, kami boleh mengurus dan mengekstrak logik yang rumit dengan cekap, memastikan model kami kekal teratur, boleh diselenggara dan berskala apabila ia berkembang dalam kerumitan.
Atas ialah kandungan terperinci Trik Fasih: Model Laravel daripada Subquery. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!