Mencapai Had Baris Maksimum dalam Jadual MySQL
Keperluan untuk mewujudkan bilangan baris maksimum yang ketat dalam jadual MySQL menimbulkan cabaran, kerana MAX_ROWS sifat jadual hanya berfungsi sebagai petunjuk kepada enjin pangkalan data. Untuk menguatkuasakan had keras, pertimbangkan pendekatan berikut:
Kuatkuasakan Had dengan Pencetus
Buat pencetus SEBELUM INSERT untuk memantau bilangan baris:
DELIMITER $$ CREATE TRIGGER trigger1 BEFORE INSERT ON table1 FOR EACH ROW BEGIN SELECT COUNT(*) INTO @cnt FROM table1; IF @cnt >= 25 THEN CALL sth(); -- raise an error END IF; END $$ DELIMITER ;
Awas: COUNT operasi pada jadual InnoDB yang besar boleh menjadi perlahan.
Tingkatkan Ralat pada Limpahan
Ubah suai pencetus untuk menimbulkan ralat secara eksplisit apabila melebihi had:
CREATE TRIGGER trigger1 BEFORE INSERT ON table1 FOR EACH ROW BEGIN DECLARE rowCount INT; SELECT COUNT(*) INTO rowCount FROM table1; IF (rowCount >= 25) THEN SIGNAL SQLSTATE '42000' SET MESSAGE_TEXT = 'Maximum row count reached (25)'; END IF; END
Pertimbangan Prestasi
Perhatikan bahawa operasi COUNT yang kerap pada jadual besar boleh menjejaskan prestasi. Untuk mengurangkan perkara ini, pertimbangkan untuk mengoptimumkan jadual dan mengindeksnya dengan sewajarnya.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menguatkuasakan Had Baris yang Ketat dalam Jadual MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!