Dalam aplikasi web berskala besar, pengoptimuman pangkalan data adalah salah satu pautan penting untuk memastikan prestasi tinggi sistem. Sebagai salah satu pangkalan data sumber terbuka yang paling popular pada masa ini, MySQL menyediakan kami dengan banyak kaedah pengoptimuman, antaranya jadual partition adalah kaedah yang biasa digunakan. Jadual partition membahagikan jadual besar kepada berbilang sub-jadual mengikut syarat tertentu, yang boleh meningkatkan kecekapan pertanyaan dan kelajuan penambahan, pemadaman dan pengubahsuaian data.
Dalam pengaturcaraan PHP, kita boleh mengoptimumkan jadual partition MySQL dalam dua cara:
Kita boleh gunakan jadual partition secara langsung dalam pernyataan pertanyaan SQL untuk mencapai kesan pengoptimuman. Contohnya, apabila kami menanyakan rekod pesanan pengguna, kami boleh menulis pernyataan SQL seperti berikut:
SELECT * FROM orders WHERE user_id = 100 AND create_time > '2021-01-01' AND create_time < '2022-01-01';
Jika jadual pesanan sangat besar, kami boleh membahagikannya mengikut medan create_time. Mula-mula kita boleh membuat jadual pesanan yang dibahagikan mengikut bulan:
CREATE TABLE orders ( id INT NOT NULL AUTO_INCREMENT, user_id INT, order_time DATETIME, amount DECIMAL(10,2), PRIMARY KEY (id, order_time) ) PARTITION BY RANGE (TO_DAYS(order_time)) ( PARTITION p202101 VALUES LESS THAN (TO_DAYS('2021-02-01')), PARTITION p202102 VALUES LESS THAN (TO_DAYS('2021-03-01')), PARTITION p202103 VALUES LESS THAN (TO_DAYS('2021-04-01')), ... PARTITION p202112 VALUES LESS THAN (TO_DAYS('2022-01-01')) );
Dengan cara ini, apabila kami menanyakan pesanan, kami boleh membuat pertanyaan berdasarkan keadaan user_id dan create_time, dan MySQL secara automatik akan memilih partition yang sepadan untuk meningkatkan kecekapan pertanyaan.
Rangka kerja ORM ialah alatan yang secara automatik memetakan objek dan jadual pangkalan data Kami boleh menggunakan rangka kerja ORM untuk mengautomasikan jadual partition. Sebagai contoh, jika kita menggunakan rangka kerja Yii2, kita boleh menggunakan pakej sambungan yii2-partition untuk membahagikan jadual secara automatik. Kita hanya perlu mengkonfigurasi jadual partition untuk mengoptimumkan jadual partition.
Pertama, kita perlu menambah konfigurasi jadual partition dalam fail konfigurasi rangka kerja Yii2:
return [ // ... 'components' => [ 'db' => [ 'class' => 'yiidbConnection', 'dsn' => 'mysql:host=localhost;dbname=mydatabase', 'username' => 'root', 'password' => 'password', 'charset' => 'utf8mb4', 'enableSchemaCache' => true, 'schemaCacheDuration' => 3600, 'partitioning' => [ 'userName' => [ 'type' => 'RANGE', 'expression' => 'MONTH(create_time)', 'column' => 'user_id', 'partitionConfig' => [ 'type' => 'RANGE', 'expression' => 'MONTH(create_time)', 'partitionCount' => 12, 'lowerBound' => 1, 'upperBound' => 12, ], ], ], // ... ], ], // ... ];
Antaranya, kami mengkonfigurasi jadual partition melalui item konfigurasi partitioning. Di sini kami mengambil nama pengguna sebagai contoh, gunakan jenis partition RANGE, partition mengikut medan BULAN (create_time) dan bahagikannya kepada 12 sub-jadual.
Seterusnya, kita perlu menentukan jadual partition dalam kelas Model yang sepadan:
class Order extends yiidbActiveRecord { public static function tableName() { return '{{%order}}_userName'; } // ... }
Dengan cara ini, kami boleh menggunakan jadual partition secara automatik untuk meningkatkan prestasi semasa mengendalikan Pesanan.
Ringkasan
Dalam pengaturcaraan PHP, kita boleh mengoptimumkan jadual partition MySQL dengan menggunakan jadual partition secara langsung dalam pernyataan SQL atau menggunakan rangka kerja ORM untuk mengautomasikan jadual partition. Dalam aplikasi tertentu, kaedah yang sesuai perlu dipilih mengikut situasi tertentu, dan diselaraskan dan dioptimumkan mengikut situasi sebenar.
Atas ialah kandungan terperinci Pengoptimuman jadual partition MySQL: aplikasi dalam pengaturcaraan PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!