Kunci untuk menentukan hubungan model menggunakan Orm fasih di Laravel adalah untuk memahami jenis hubungan yang sama dan menetapkannya dengan betul. 1. Hubungan umum termasuk satu-satu, satu-ke-banyak, milik, jauh dari satu-ke-banyak (Hasmany) dan hubungan polimorfik; 2. Hubungan satu-ke-banyak ditakrifkan oleh kaedah Hasmany, dan ID utama utama dipadankan dengan lalai kepada user_id utama asing, dan kunci asing juga boleh ditentukan secara manual; 3. Banyak hubungan yang memerlukan jadual pertengahan dan ditakrifkan oleh kepunyaan, yang boleh menentukan nama jadual pertengahan dan memuatkan medan tambahan denganpivot; 4. Gunakan dengan () untuk pramuat untuk mengelakkan masalah pertanyaan n 1, dan menyokong pemuatan bersarang dan pemuatan bersyarat.
Di Laravel, Orm fasih menyediakan cara yang sangat mudah untuk mengendalikan hubungan antara model pangkalan data. Sebaik sahaja hubungan ini ditakrifkan, anda boleh mengakses data yang berkaitan tanpa menulis pernyataan pertanyaan kompleks. Kuncinya adalah untuk memahami beberapa jenis hubungan biasa dan menetapkannya dengan betul dalam model.

1. Memahami jenis hubungan fasih biasa
Laravel menyokong hubungan antara pelbagai model, dan yang paling biasa digunakan adalah seperti berikut:

- Satu hingga satu : Sebagai contoh, pengguna mempunyai nombor telefon bimbit.
- Satu kepada banyak : Sebagai contoh, pengguna boleh mempunyai beberapa pesanan.
- Ramai kepada ramai : Sebagai contoh, terdapat banyak hubungan antara pengguna dan peranan. Pengguna boleh mempunyai pelbagai peranan, dan peranan juga boleh diberikan kepada beberapa pengguna.
- Mempunyai banyak melalui : contohnya, pengguna boleh mendapatkan kandungan komen semua pesanannya.
- Hubungan Polymorphic : Digunakan dalam situasi di mana model boleh tergolong dalam pelbagai model lain, seperti komen boleh dimiliki oleh artikel atau video.
Setiap hubungan mempunyai kaedah fasih yang sepadan untuk menentukan, seperti hasOne
, hasMany
, belongsToMany
, dll.
2. Bagaimana untuk menentukan hubungan "satu-ke-banyak"?
Ini adalah salah satu hubungan yang paling biasa. Katakan anda mempunyai dua model: pengguna dan pos, dan satu pengguna boleh menerbitkan pelbagai artikel.

Tambahkan kaedah berikut kepada model pengguna:
Catatan Fungsi Awam () { kembali $ this-> hasmany (post :: class); }
Secara lalai, Laravel secara automatik menggunakan ID utama utama pengguna untuk memadankan medan user_id dalam jadual pos. Sekiranya medan jadual data anda berbeza, anda boleh menentukannya secara manual:
kembali $ this-> hasmany (pos :: kelas, 'user_id_foreign');
Kemudian anda boleh memanggilnya seperti ini:
$ user = user :: cari (1); foreach ($ user-> posts as $ post) { echo $ post-> tajuk; }
3. Perhatikan jadual pertengahan ketika menentukan hubungan "banyak-banyak"
Mengambil pengguna dan peranan sebagai contoh, anda memerlukan tiga jadual: pengguna, peranan, dan role_user (jadual pertengahan).
Ditakrifkan dalam model pengguna:
Peranan Fungsi Awam () { kembali $ this-> milikStomany (peranan :: kelas); }
Begitu juga, jadual perantaraan lalai disambungkan abjad (role_user). Jika tidak, anda boleh lulus dalam parameter untuk menentukan:
kembali $ this-> milikStomany (peranan :: kelas, 'user_role');
Jika jadual perantaraan anda mempunyai medan tambahan, seperti Created_at atau maklumat lain, anda boleh memuatkan medan ini melalui withPivot
:
kembali $ this-> milikStomany (peranan :: kelas)-> withPivot ('created_at');
4. Gunakan dengan () untuk pramuat untuk mengelakkan masalah pertanyaan n 1
Apabila anda gelung melalui model dan mengakses hubungannya, jika tidak ada pramuat yang dilakukan, setiap gelung memulakan pertanyaan baru. Ini boleh menyebabkan kemerosotan prestasi.
Cara yang betul untuk melakukan ini adalah menggunakan with()
semasa menanyakan:
$ users = user :: with ('posts')-> get (); foreach ($ pengguna sebagai pengguna $) { foreach ($ user-> posts as $ post) { // Tiada pertanyaan tambahan dihasilkan di sini} }
Anda juga boleh memuatkan sarang:
Pengguna :: dengan ('poss.comments')-> get ();
Atau memuatkan dengan keadaan:
Pengguna :: dengan (['siaran' => fungsi ($ query) { $ query-> where ('diterbitkan', benar); }])-> mendapatkan ();
Pada dasarnya itu sahaja. Kunci untuk menentukan hubungan yang fasih adalah untuk memahami struktur logik antara model dan kemudian pilih kaedah dan parameter yang sesuai untuk menyatakannya. Walaupun ia mungkin agak mengelirukan pada mulanya, anda akan mendapati bahawa ia sangat memudahkan operasi pangkalan data selepas mengenalinya.
Atas ialah kandungan terperinci Bagaimana untuk menentukan hubungan yang fasih di Laravel?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

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

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

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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

Inlaravel, policiesorganizeAuthorizationLogicformodelactions.1.PoliciesareClassSesSesSelSelwithMethodsLikeView, create, Update, andDeletetHatReturnTrueorfalsebasedOnuserpermissions.2.Toregisterapolicy, Mapthemodeltoitspolicheon.

Untuk membuat rekod baru dalam pangkalan data menggunakan fasih, terdapat empat kaedah utama: 1. Gunakan kaedah membuat untuk membuat rekod dengan cepat dengan lulus dalam array atribut, seperti pengguna :: create (['name' => 'Johndoe', 'e -mel' => 'John@example.com']); 2. Gunakan kaedah simpan untuk secara manual meniru model dan menetapkan nilai untuk menyimpan satu demi satu, yang sesuai untuk senario di mana tugasan bersyarat atau logik tambahan diperlukan; 3. Gunakan FirstOrcreate untuk mencari atau membuat rekod berdasarkan keadaan carian untuk mengelakkan data pendua; 4. Gunakan UpdateOrcreate untuk mencari rekod dan kemas kini, jika tidak, buatnya, yang sesuai untuk memproses data yang diimport, dan lain -lain, yang mungkin berulang.

Artisan adalah alat perintah Laravel untuk meningkatkan kecekapan pembangunan. Fungsi terasnya termasuk: 1. Menjana struktur kod, seperti pengawal, model, dan lain -lain, dan secara automatik membuat fail melalui membuat: pengawal dan arahan lain; 2. Menguruskan penghijrahan pangkalan data dan mengisi, gunakan berhijrah untuk menjalankan penghijrahan, dan DB: benih untuk mengisi data; 3. Menyokong perintah adat, seperti Make: Command Creation Command Class untuk melaksanakan enkapsulasi logik perniagaan; 4. Memberi fungsi debugging dan pengurusan alam sekitar, seperti kunci: menjana untuk menjana kunci, dan berfungsi untuk memulakan pelayan pembangunan. Kemahiran dalam menggunakan Artisan dapat meningkatkan kecekapan pembangunan Laravel dengan ketara.

Ya, youpaninstalllaravelonanyoperatingsystembyfollowingthesesteps: 1.InstallphpandrequiredextensionsLikembstring, openssl, andxmlusingtoolsLikexampponWindows, homeBrewonmacos, oraptonlarunux;

Menentukan kaedah (juga dikenali sebagai tindakan) dalam pengawal adalah untuk memberitahu aplikasi apa yang perlu dilakukan apabila seseorang melawat URL tertentu. Kaedah ini biasanya memproses permintaan, memproses data, dan mengembalikan respons seperti halaman HTML atau JSON. Memahami Struktur Asas: Kebanyakan kerangka web (seperti RubyonRails, Laravel, atau SpringMVC) menggunakan pengawal yang berkaitan dengan operasi kumpulan. Kaedah dalam setiap pengawal biasanya sesuai dengan laluan, iaitu laluan URL yang dapat diakses oleh seseorang. Sebagai contoh, mungkin terdapat kaedah berikut dalam PostSController: 1.Index () - Senarai Pos Paparan; 2.Show () - memaparkan jawatan individu; 3.Create () - Mengendalikan membuat jawatan baru; 4.U

Toruntestsinlaravelefectively, usethephpartiSanteStCommandWhichSimplifiesphpunitusage.1.setupa.env.testingfileandConfigurePhp Unit.xmltouseatestDatabaselikesqlite.2.GenerateTestFilesusingPhpartisanMake: ujian, menggunakan-Unitforunittests.3.WriteTestSwithmeth

Peranan utama pengawal di Laravel adalah untuk memproses permintaan HTTP dan mengembalikan respons untuk memastikan kod itu kemas dan dikekalkan. Dengan menumpukan logik permintaan yang berkaitan ke dalam kelas, pengawal membuat fail penghalaan lebih mudah, seperti meletakkan paparan profil pengguna, pengeditan dan operasi pemadaman dalam kaedah usercontroller yang berbeza. Penciptaan pengawal boleh dilaksanakan melalui arahan Artisan PhPartisanMake: ControllerUserController, manakala pengawal sumber dijana menggunakan pilihan -sumber, meliputi kaedah untuk operasi CRUD standard. Kemudian anda perlu mengikat pengawal dalam laluan, seperti Route :: Get ('/user/{id

Laravel membolehkan pandangan dan logik pengesahan tersuai dengan mengatasi stub lalai dan pengawal. 1. Untuk menyesuaikan pandangan pengesahan, gunakan arahan PhPartisanVendor: Publish-Tag = Laravel-Auth untuk menyalin templat bilah lalai ke direktori sumber/pandangan/auth dan mengubahnya, seperti menambah kotak semak "Syarat Perkhidmatan". 2. Untuk mengubah suai logik pengesahan, anda perlu menyesuaikan kaedah dalam registerController, logincontroller dan resetpasswordcontroller, seperti mengemas kini kaedah validator () untuk mengesahkan medan tambahan, atau menulis semula r
