亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

創建表沒有問題,創建觸發器總是提示“end if end ”處有錯誤?為什么

創建表沒有問題,創建觸發器總是提示“end if end ”處有錯誤?為什么

Helenr 2023-02-17 18:10:07
//創建表的語句沒有問題CREATE TABLE `web_record` (`timestamp` decimal(15,3) DEFAULT NULL,`resp_time` int(11) DEFAULT NULL,`src_ip` char(15) DEFAULT NULL,`cache_status` varchar(20) DEFAULT NULL,`http_status` varchar(10) DEFAULT NULL,`reply_size` int(11) DEFAULT NULL,`req_method` varchar(20) DEFAULT NULL,`req_uri` varchar(1000) DEFAULT NULL,`username` varchar(20) DEFAULT NULL,`peer_access` varchar(20) DEFAULT NULL,`dst_ip` char(15) DEFAULT NULL,`mime_type` varchar(50) DEFAULT NULL,`domain` varchar(200) DEFAULT NULL,`id` bigint(20) NOT NULL AUTO_INCREMENT,PRIMARY KEY (`id`),KEY `id` (`id`))// 創建觸發器的語句報錯CREATE TRIGGER domain_Fill BEFORE INSERT ON `web_record`FOR EACH ROWBEGINIF (LOCATE('://',NEW.`req_uri`)) THENSET NEW.`domain` = SUBSTRING_INDEX(SUBSTRING_INDEX(NEW.`req_uri`,'/',3),'/',-2)END IF END創建表沒有問題,創建觸發器總是提示“#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'END IF END' at line 6”
查看完整描述

2 回答

?
開心每一天1111

TA貢獻1836條經驗 獲得超13個贊

在 SET NEW.`domain` = SUBSTRING_INDEX(SUBSTRING_INDEX(NEW.`req_uri`,'/',3),'/',-2)
後面加上分號,END IF 後面也是

查看完整回答
反對 回復 2023-02-20
?
眼眸繁星

TA貢獻1873條經驗 獲得超9個贊

// 創建觸發器的語句報錯
應該先寫on 后寫 before insert吧
CREATE TRIGGER domain_Fill ON `web_record` BEFORE INSERT 
FOR EACH ROW
BEGIN
IF (LOCATE('://',NEW.`req_uri`)) THEN
SET NEW.`domain` = SUBSTRING_INDEX(SUBSTRING_INDEX(NEW.`req_uri`,'/',3),'/',-2)
END IF 
END

查看完整回答
反對 回復 2023-02-20
  • 2 回答
  • 0 關注
  • 124 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號