在MySQL 中使用觸發器定義自增複合鍵
MySQL 允許建立涉及多列的複合鍵,但可以是為這些鍵配置自動增量很棘手,尤其是對於InnoDB
場景
考慮一個具有兩個外鍵和一個自動增量列作為複合主鍵一部分的表:
CREATE TABLE `issue_log` ( `sr_no` INT NOT NULL AUTO_INCREMENT, `app_id` INT NOT NULL, `test_id` INT NOT NULL, `issue_name` VARCHAR(255) NOT NULL, PRIMARY KEY (app_id, test_id, sr_no) );
自動增量的限制InnoDB
InnoDB 將自動增量限制為主鍵中的單一欄位。如果您嘗試將sr_no 定義為自動增量和複合鍵的一部分,您將遇到錯誤,指出「表定義不正確;只能有一個自動列,並且必須將其定義為鍵。」
解決方案:使用觸發器
要實現此場景,可以使用觸發器自動設定每次INSERT 操作之前的sr_no:
DELIMITER $$ CREATE TRIGGER xxx BEFORE INSERT ON issue_log FOR EACH ROW BEGIN SET NEW.sr_no = ( SELECT IFNULL(MAX(sr_no), 0) + 1 FROM issue_log WHERE app_id = NEW.app_id AND test_id = NEW.test_id ); END $$ DELIMITER ;
此觸發器透過尋找給定app_id 和test_id 的最大現有值來計算sr_no 的新值,然後將其遞增1。透過使用觸發器,您可以確保為每個新行正確設定sr_no,即使它沒有直接定義為自動增量
注意:請記住調整表結構和觸發器定義以符合您的特定表格名稱和欄位名稱。
以上是MySQL中如何使用觸發器定義自增複合鍵?的詳細內容。更多資訊請關注PHP中文網其他相關文章!