Laravel ialah rangka kerja pembangunan PHP yang sangat baik yang menyediakan sokongan kuat dalam melaksanakan operasi ORM (Pemetaan Perhubungan Objek). Walau bagaimanapun, untuk sesetengah aplikasi data besar, kami mungkin perlu membahagikan jadual untuk mengurus data dengan lebih baik. Jadi, bagaimanakah Laravel melaksanakan jadual berpecah?
1. Prinsip subjadual Laravel
Dalam Laravel, asas model data ialah Eloquent ORM. Apabila kita menggunakan model Eloquent untuk mengakses pangkalan data, Laravel akan menjana nama jadual pangkalan data yang sepadan berdasarkan nama model. Sebagai contoh, kami mempunyai kelas model User
, Laravel secara lalai akan mengakses jadual pangkalan data bernama users
.
Kemudian, prinsip pembahagian jadual adalah sangat mudah. Kita hanya perlu mentakrifkan atribut $table
dalam kelas model untuk menentukan nama jadual. Untuk kes jadual berpecah, kita boleh mengakses jadual yang berbeza dengan mengubah suai atribut $table
secara dinamik dalam kelas model.
2. Pelaksanaan sub-jadual dalam Laravel
Seterusnya, mari kita lihat cara melaksanakan sub-jadual dalam Laravel.
1. Ubah suai nama jadual secara manual
Melalui Eloquent ORM, kami boleh mengakses jadual pangkalan data yang berbeza dengan mengubah suai atribut $table
kelas model secara manual.
Sebagai contoh, kami mempunyai kelas model bernama Order
dan perlu membahagikan jadual pesanan kepada dua jadual: order_1
dan order_2
. Kemudian, kita hanya perlu mentakrifkan kod berikut dalam kelas model:
use IlluminateDatabaseEloquentModel; class Order extends Model { //连接到模型的数据表 protected $table = 'order_1'; }
Dengan cara ini, apabila anda mengakses model, ia akan secara automatik menghala ke jadual order_1
.
Jika kita ingin mengakses jadual order_2
, kita hanya perlu mengubah suai atribut $table
kelas model.
use IlluminateDatabaseEloquentModel; class Order extends Model { //连接到模型的数据表 protected $table = 'order_2'; }
2. Pembahagian jadual automatik
Walaupun mengubah suai nama jadual secara manual mudah dilaksanakan, apabila terdapat terlalu banyak jadual yang dipecahkan, pengubahsuaian manual menjadi rumit dan mudah ralat. Oleh itu, kita boleh mencipta kelas jadual untuk Laravel mengurus nama jadual secara automatik.
Dalam Laravel, kami boleh mencipta kelas kilang model untuk mengautomasikan pembahagian meja. Sebagai contoh, kami mempunyai kelas model bernama Order
, dan kami perlu membahagikan jadual pesanan kepada beberapa jadual kecil berdasarkan ID pengguna. Kita boleh mencipta kelas kilang model bernama OrderFactory
untuk menjana nama jadual secara dinamik dan mengurus nama jadual secara automatik.
use IlluminateSupportFacadesDB; use IlluminateDatabaseEloquentModel; class OrderFactory { private $userId; private $tableName = 'orders_'; public function __construct($userId) { $this->userId = $userId; $this->tableName .= $this->getTableName(); } public function makeModel() { $model = new Model(); $model->setTable($this->tableName); return $model; } protected function getTableName() { $tableId = intval($this->userId) % 10 + 1; return $tableId; } }
Dalam kelas kilang, kami mengira ID jadual yang sepadan berdasarkan ID pengguna untuk menjana nama jadual yang betul. Apabila menjana model, kami hanya memanggil kaedah makeModel
.
Sebagai contoh, jika kita perlu mendapatkan senarai pesanan dengan ID pengguna 123, kita boleh memanggilnya seperti berikut:
$factory = new OrderFactory(123); $order = $factory->makeModel()->get();
Dengan cara ini, kami telah berjaya melaksanakan operasi pemisahan jadual dalam Laravel .
3. Kelebihan dan Kelemahan Perkongsian Jadual Laravel
Walaupun sharding boleh membawa banyak kelebihan dalam beberapa kes, sharding juga mempunyai beberapa kelemahan.
1. Kelebihan
(1) Peningkatan prestasi
Apabila jumlah data adalah besar, pembahagian jadual boleh mengurangkan jumlah data dalam jadual, dengan itu meningkatkan kecekapan pertanyaan . Pada masa yang sama, disebabkan klasifikasi data, kami boleh menggunakan kaedah pengindeksan yang lebih baik untuk mengoptimumkan kelajuan pertanyaan.
(2) Kebolehskalaan
Apabila jumlah data berkembang ke had, kami boleh menggunakan jadual serpihan untuk mengembangkan pangkalan data untuk mencapai kebolehskalaan yang lebih tinggi.
2. Kelemahan
(1) Pembaziran ruang
Sub-jadual akan menyebarkan data ke dalam beberapa jadual, yang akan menyebabkan pembaziran ruang tertentu. Sebagai contoh, jika kita membahagikan jadual mengikut ID pengguna, dan pengguna tertentu mempunyai data yang sangat sedikit berbanding pengguna lain, maka akan terdapat banyak data kosong dalam jadual lain.
(2) Tingkatkan kesukaran pembangunan
Menggunakan sub-jadual akan menyerakkan data ke dalam berbilang jadual, yang akan membawa kerumitan tertentu kepada penyelenggaraan jadual data. Pada masa yang sama, menggunakan sub-jadual juga memerlukan pengoptimuman kod yang sepadan, yang meningkatkan kesukaran pembangunan.
Ringkasnya, pelaksanaan sub-jadual Laravel boleh membawa prestasi dan kebolehskalaan yang lebih tinggi kepada aplikasi dalam keadaan data besar, tetapi ia juga membawa beberapa kerumitan dan masalah sisa ruang Apabila kita menggunakannya ditimbang mengikut kes.
Atas ialah kandungan terperinci Pelaksanaan jadual laravel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!