Rumah rangka kerja php Laravel Bagaimana untuk menanyakan atribut tambahan jadual perantaraan dalam laravel

Bagaimana untuk menanyakan atribut tambahan jadual perantaraan dalam laravel

Apr 12, 2023 am 09:13 AM

Dalam Laravel, jadual perantaraan biasanya digunakan untuk memproses perhubungan banyak-ke-banyak. Contohnya, blog boleh mempunyai berbilang tag dan tag boleh digunakan oleh berbilang blog. Perhubungan ini boleh dikendalikan menggunakan jadual perantaraan, yang menyimpan perhubungan yang sepadan antara setiap blog dan teg.

Walau bagaimanapun, dalam beberapa kes, jadual perantaraan mungkin perlu menyimpan data tambahan, seperti masa penciptaan perhubungan antara teg dan blog. Dalam kes ini, kita perlu menggunakan atribut tambahan jadual perantaraan untuk menyimpan data ini.

Menggunakan sifat tambahan jadual perantaraan boleh dicapai melalui "model jadual perantaraan" dalam Laravel. Kelas model ini digunakan untuk mengurus jadual perantaraan dan menyediakan banyak fungsi berguna, termasuk menanyakan sifat tambahan bagi jadual perantaraan.

Pertama, kita perlu mencipta kelas model jadual perantaraan. Kelas ini boleh dibuat menggunakan perintah Artisan:

php artisan make:model Taggable --pivot
Salin selepas log masuk

Apabila menjalankan arahan ini, kita perlu memberikan nama jadual perantaraan, yang sepatutnya dinamakan "Table1_Table2" mengikut konvensyen Laravel.

Selepas mencipta model jadual perantaraan, kita boleh menentukan atribut tambahan jadual perantaraan dalam model yang berkaitan. Sebagai contoh, jika kita mempunyai model "blog" dan model "tag" dan mengaitkannya menggunakan jadual perantaraan, kita boleh mentakrifkan perkaitan seperti ini:

class Post extends Model
{
    public function tags()
    {
        return $this->belongsToMany(Tag::class)
                    ->using(Taggable::class)
                    ->withPivot('created_at');
    }
}
Salin selepas log masuk

Dalam contoh ini, kami menggunakan The menentukan model jadual perantaraan sebagai using() dan menggunakan kaedah Taggable untuk menentukan atribut tambahan jadual perantaraan. withPivot()

Dengan cara ini kita boleh dengan mudah menanyakan jadual perantaraan untuk sifat tambahan. Contohnya, jika kita ingin menanyakan masa penciptaan perhubungan antara teg dan blog, kita boleh menggunakan kod berikut:

$tag = Tag::find(1);

foreach ($tag->posts as $post) {
    $pivot = $post->pivot;
    $createdAt = $pivot->created_at;
    // do something with $createdAt
}
Salin selepas log masuk
Dalam contoh ini, kita mula-mula mendapatkan model teg, dan kemudian lulus Ahli Gabungan model Lawati blognya. Untuk setiap blog, kita boleh mendapatkan contoh model jadual perantaraan dan menggunakan sifatnya untuk mengakses sifat tambahan jadual perantaraan.

Ringkasnya, menggunakan sifat tambahan jadual perantaraan boleh memberikan lebih fleksibiliti dan fungsi apabila membangunkan perhubungan banyak-ke-banyak. Dengan menggunakan model jadual perantaraan dan menambah kaedah

semasa mentakrifkan perhubungan, kita boleh menanyakan sifat tambahan jadual perantaraan dan memanfaatkan sepenuhnya kuasa Laravel. withPivot()

Atas ialah kandungan terperinci Bagaimana untuk menanyakan atribut tambahan jadual perantaraan dalam laravel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Mana yang lebih baik, Django atau Laravel? Mana yang lebih baik, Django atau Laravel? Mar 28, 2025 am 10:41 AM

Kedua-dua Django dan Laravel adalah kerangka kerja penuh. Django sesuai untuk pemaju python dan logik perniagaan yang kompleks, manakala Laravel sesuai untuk pemaju PHP dan sintaks elegan. 1.Django didasarkan pada python dan mengikuti falsafah "lengkap bateri", sesuai untuk perkembangan pesat dan kesesuaian yang tinggi. 2. Laravel didasarkan pada PHP, menekankan pengalaman pemaju, dan sesuai untuk projek kecil dan sederhana.

Laravel dan backend: Powering Web Application Logic Laravel dan backend: Powering Web Application Logic Apr 11, 2025 am 11:29 AM

Bagaimanakah Laravel memainkan peranan dalam logik backend? Ia memudahkan dan meningkatkan pembangunan backend melalui sistem penghalaan, eloquentorm, pengesahan dan kebenaran, acara dan pendengar, dan pengoptimuman prestasi. 1. Sistem penghalaan membolehkan definisi struktur URL dan logik pemprosesan permintaan. 2.eloquentorm memudahkan interaksi pangkalan data. 3. Sistem pengesahan dan kebenaran adalah mudah untuk pengurusan pengguna. 4. Acara dan pendengar melaksanakan struktur kod yang ditambah dengan longgar. 5. Pengoptimuman prestasi meningkatkan kecekapan aplikasi melalui caching dan beratur.

Contoh Pengenalan Laravel Contoh Pengenalan Laravel Apr 18, 2025 pm 12:45 PM

Laravel adalah rangka kerja PHP untuk membina aplikasi web yang mudah. Ia menyediakan pelbagai ciri yang kuat termasuk: Pemasangan: Pasang Laravel CLI secara global dengan komposer dan buat aplikasi dalam direktori projek. Routing: Tentukan hubungan antara URL dan pengendali dalam laluan/web.php. Lihat: Buat pandangan dalam sumber/pandangan untuk menjadikan antara muka aplikasi. Integrasi Pangkalan Data: Menyediakan integrasi keluar-of-the-box dengan pangkalan data seperti MySQL dan menggunakan penghijrahan untuk membuat dan mengubah suai jadual. Model dan Pengawal: Model mewakili entiti pangkalan data dan proses pengawal permintaan HTTP.

PHP atau Laravel mana yang lebih baik? PHP atau Laravel mana yang lebih baik? Mar 27, 2025 pm 05:31 PM

PHP dan Laravel tidak dapat dibandingkan secara langsung, kerana Laravel adalah rangka kerja berasaskan PHP. 1.Php sesuai untuk projek kecil atau prototaip cepat kerana ia mudah dan langsung. 2. Laravel sesuai untuk projek besar atau pembangunan yang cekap kerana ia menyediakan fungsi dan alat yang kaya, tetapi mempunyai lengkung pembelajaran yang curam dan mungkin tidak sebaik php tulen.

Adakah Laravel adalah frontend atau backend? Adakah Laravel adalah frontend atau backend? Mar 27, 2025 pm 05:31 PM

LaravelisabackendFramWorkBuiltonPHP, Direka ForweBapplicationDevelopment.itfocusesonServer-Sidelogic, DatabaseManagement, andApplications Structure, andCanbeIntegratedWithFrontendTechnologiesLikeVue.jsorreactorfull-stackdevelopment.

Fungsi log masuk pengguna laravel Fungsi log masuk pengguna laravel Apr 18, 2025 pm 12:48 PM

Laravel menyediakan rangka kerja auth yang komprehensif untuk melaksanakan fungsi log masuk pengguna, termasuk: Menentukan model pengguna (model fasih), membuat borang log masuk (enjin templat bilah), menulis pengawal log masuk (mewarisi auth \ logincontroller) tajuk keselamatan. Di samping itu, rangka kerja AUTH juga menyediakan fungsi seperti menetapkan semula kata laluan, mendaftar dan mengesahkan e -mel. Untuk maklumat lanjut, sila rujuk dokumentasi Laravel: https://laravel.com/doc

Cara Belajar Laravel Cara Belajar Laravel secara percuma Cara Belajar Laravel Cara Belajar Laravel secara percuma Apr 18, 2025 pm 12:51 PM

Mahu mempelajari rangka kerja Laravel, tetapi tidak mengalami sumber atau tekanan ekonomi? Artikel ini memberikan anda pembelajaran percuma Laravel, mengajar anda cara menggunakan sumber seperti platform dalam talian, dokumen dan forum komuniti untuk meletakkan asas yang kukuh untuk perjalanan pembangunan PHP anda dari mula menguasai.

Perkongsian Kemahiran Kerangka Laravel Perkongsian Kemahiran Kerangka Laravel Apr 18, 2025 pm 01:12 PM

Dalam era kemajuan teknologi yang berterusan, menguasai kerangka lanjutan adalah penting untuk pengaturcara moden. Artikel ini akan membantu anda meningkatkan kemahiran pembangunan anda dengan berkongsi teknik yang kurang dikenali dalam rangka kerja Laravel. Dikenali dengan sintaks yang elegan dan pelbagai ciri, artikel ini akan menggali ciri -ciri yang kuat dan memberikan tips dan cara praktikal untuk membantu anda membuat aplikasi web yang cekap dan boleh dipelihara.

See all articles