Rumah rangka kerja php Laravel Bagaimana untuk mengelakkan carian jadual dalam laravel

Bagaimana untuk mengelakkan carian jadual dalam laravel

Apr 21, 2023 am 10:01 AM

Menggunakan Pemetaan Perhubungan dalam Laravel boleh mengelakkan masalah menggunakan foreach untuk mencari jadual. Pemetaan hubungan ialah salah satu ciri ORM (Pemetaan hubungan objek) Laravel yang berkuasa, yang boleh secara automatik mewujudkan hubungan antara jadual dalam model.

Dalam Laravel, terdapat tiga jenis pemetaan hubungan: Satu-dengan-satu, Satu-ke-banyak dan Banyak-ke-banyak. Pemetaan hubungan ini boleh ditakrifkan dan diwujudkan melalui model Eloquent. Di bawah ini kami akan memperkenalkan penggunaan dan pelaksanaan ketiga-tiga pemetaan hubungan ini secara terperinci berdasarkan amalan.

Pemetaan satu dengan satu

Pemetaan satu dengan satu selalunya digunakan apabila dua jadual berkongsi kunci utama yang sama Satu baris data dalam satu jadual hanya boleh sepadan dengan jadual lain. Contohnya, jadual Pesanan dan jadual Pelanggan. Setiap pesanan hanya dimiliki oleh seorang pelanggan, dan setiap pelanggan hanya mempunyai satu pesanan. Dalam kes ini, lajur ID pelanggan bagi jadual pesanan ialah lajur kunci utama dalam jadual pelanggan.

Dalam Eloquent, kita boleh mentakrifkan dua model: model pesanan dan model pelanggan, dan mewujudkan pemetaan hubungan satu dengan satu antara dua model ini:

// 订单模型
class Order extends Model
{
    public function customer()
    {
        return $this->hasOne(Customer::class);
    }
}

// 客户模型
class Customer extends Model
{
    public function order()
    {
        return $this->belongsTo(Order::class);
    }
}
Salin selepas log masuk

Dalam perkara di atas Dalam kod, kami mentakrifkan kaedah perhubungan dalam model Pesanan dan Pelanggan, masing-masing pelanggan dan pesanan. Kedua-dua kaedah perhubungan menggunakan kaedah hasOne dan belongsTo dalam model Eloquent untuk mewujudkan pemetaan hubungan satu dengan satu antara kedua-dua model.

Apabila kami perlu mencari maklumat pelanggan untuk pesanan, kami hanya perlu menggunakan kaedah $order->customer:

$order = Order::find($id);
$customer = $order->customer;
Salin selepas log masuk

Pemetaan satu-ke-banyak

Pemetaan satu-ke-banyak selalunya digunakan di mana satu baris data dalam jadual boleh sepadan dengan baris data dalam berbilang jadual. Contohnya, pengguna mempunyai berbilang artikel, atau jabatan mempunyai berbilang pekerja. Dalam kes ini, kita perlu menggunakan kaedah hasMany dan belongsTo dalam model Eloquent yang berkaitan untuk mewujudkan pemetaan hubungan satu-ke-banyak.

Mengambil jadual pengguna dan jadual artikel sebagai contoh, kita perlu mewujudkan pemetaan hubungan satu-ke-banyak dalam model Pengguna dan Artikel:

// 用户模型
class User extends Model
{
    public function articles()
    {
        return $this->hasMany(Article::class);
    }
}

// 文章模型
class Article extends Model
{
    public function user()
    {
        return $this->belongsTo(User::class);
    }
}
Salin selepas log masuk

Dalam kod di atas, kita berada dalam model Pengguna Kaedah perhubungan yang dinamakan artikel ditakrifkan, dan pemetaan satu-ke-banyak antara pengguna dan artikel dilaksanakan melalui kaedah hasMany. Kaedah perhubungan bernama pengguna ditakrifkan dalam model Artikel, dan pemetaan perhubungan banyak dengan satu antara artikel dan pengguna dilaksanakan melalui kaedah belongsTo.

Apabila kita perlu mencari semua artikel pengguna, kita hanya perlu menggunakan kaedah $user->articles:

$user = User::find($id);
$articles = $user->articles;
Salin selepas log masuk

Pemetaan banyak-ke-banyak

Pemetaan hubungan banyak-ke-banyak sering digunakan apabila terdapat hubungan banyak-ke-banyak antara dua jadual. Contohnya, berkenaan perhubungan antara pengguna dan peranan, seorang pengguna boleh mempunyai berbilang peranan dan satu peranan juga boleh dimiliki oleh berbilang pengguna. Dalam kes ini, kita perlu menggunakan kaedah belongsToMany dalam model Eloquent untuk mewujudkan pemetaan hubungan banyak-ke-banyak.

Mengambil jadual pengguna dan jadual peranan sebagai contoh, kita perlu mewujudkan pemetaan hubungan banyak-ke-banyak dalam Model Pengguna dan Peranan:

// 用户模型
class User extends Model
{
    public function roles()
    {
        return $this->belongsToMany(Role::class);
    }
}

// 角色模型
class Role extends Model
{
    public function users()
    {
        return $this->belongsToMany(User::class);
    }
}
Salin selepas log masuk

Dalam kod di atas, kita berada dalam model Pengguna Kaedah perhubungan yang dinamakan peranan ditakrifkan, dan pemetaan perhubungan banyak-ke-banyak antara pengguna dan peranan dilaksanakan melalui kaedah belongsToMany. Kaedah perhubungan bernama pengguna ditakrifkan dalam Role model dan pemetaan perhubungan banyak-ke-banyak antara peranan dan pengguna dilaksanakan melalui kaedah belongsToMany.

Apabila kita perlu mencari semua peranan pengguna, kita hanya perlu menggunakan kaedah $user->roles:

$user = User::find($id);
$roles = $user->roles;
Salin selepas log masuk

Ringkasan

Digunakan dalam Laravel Ciri pemetaan hubungan secara berkesan boleh mengelakkan masalah menggunakan foreach untuk mencari jadual. Pemetaan hubungan satu-ke-satu, satu-ke-banyak dan banyak-ke-banyak masing-masing sepadan dengan hubungan antara jadual data yang berbeza dan ditakrifkan serta dilaksanakan melalui kaedah model Eloquent. Kita boleh mewujudkan pemetaan perhubungan dengan mentakrifkan kaedah perhubungan dalam model Eloquent yang berkaitan, menggunakan kaedah hasMany, belongsTo, dan belongsToMany. Kaedah ini membolehkan kami melaksanakan operasi pangkalan data yang kompleks dengan mudah dan mudah, dan juga menjadikan kod kami lebih jelas dan lebih mudah untuk diselenggara.

Atas ialah kandungan terperinci Bagaimana untuk mengelakkan carian jadual 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

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

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.

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.

Mengapa Laravel begitu popular? Mengapa Laravel begitu popular? Apr 02, 2025 pm 02:16 PM

Populariti Laravel termasuk proses pembangunan mudahnya, menyediakan persekitaran pembangunan yang menyenangkan, dan ciri -ciri yang kaya. 1) Ia menyerap falsafah reka bentuk Rubyonrails, menggabungkan fleksibiliti PHP. 2) Menyediakan alat seperti eloquentorm, enjin templat bilah, dan lain -lain untuk meningkatkan kecekapan pembangunan. 3) Mekanisme suntikan seni bina dan ketergantungan MVC menjadikan kod lebih modular dan boleh diuji. 4) Menyediakan alat debugging yang kuat dan kaedah pengoptimuman prestasi seperti sistem caching dan amalan terbaik.

Fleksibiliti Laravel: Dari laman web mudah ke sistem yang kompleks Fleksibiliti Laravel: Dari laman web mudah ke sistem yang kompleks Apr 13, 2025 am 12:13 AM

Projek Pembangunan Laravel telah dipilih kerana fleksibiliti dan kuasa untuk memenuhi keperluan saiz dan kerumitan yang berbeza. Laravel menyediakan sistem penghalaan, eloquentorm, baris perintah artisan dan fungsi lain, menyokong pembangunan dari blog mudah ke sistem peringkat perusahaan yang kompleks.

Laravel (PHP) vs Python: Persekitaran Pembangunan dan Ekosistem Laravel (PHP) vs Python: Persekitaran Pembangunan dan Ekosistem Apr 12, 2025 am 12:10 AM

Perbandingan antara Laravel dan Python dalam persekitaran pembangunan dan ekosistem adalah seperti berikut: 1. Persekitaran pembangunan Laravel adalah mudah, hanya PHP dan komposer diperlukan. Ia menyediakan pelbagai pakej lanjutan seperti Laravelforge, tetapi penyelenggaraan pakej lanjutan mungkin tidak tepat pada masanya. 2. Persekitaran pembangunan Python juga mudah, hanya Python dan PIP diperlukan. Ekosistem adalah besar dan meliputi pelbagai bidang, tetapi pengurusan versi dan pergantungan mungkin kompleks.

Fungsi Utama Laravel: Pembangunan Backend Fungsi Utama Laravel: Pembangunan Backend Apr 15, 2025 am 12:14 AM

Fungsi teras Laravel dalam pembangunan back-end termasuk sistem penghalaan, eloquentorm, fungsi penghijrahan, sistem cache dan sistem giliran. 1. Sistem penghalaan memudahkan pemetaan URL dan meningkatkan organisasi dan penyelenggaraan kod. 2.eloquentorm menyediakan operasi data berorientasikan objek untuk meningkatkan kecekapan pembangunan. 3. Fungsi penghijrahan menguruskan struktur pangkalan data melalui kawalan versi untuk memastikan konsistensi. 4. Sistem cache mengurangkan pertanyaan pangkalan data dan meningkatkan kelajuan tindak balas. 5. Sistem giliran berkesan memproses data berskala besar, elakkan menghalang permintaan pengguna, dan meningkatkan prestasi keseluruhan.

See all articles