我的触发器在这里。
mysql> CREATE TRIGGER `trg_after_insert` AFTER INSERT ON `tbl_demo`
-> FOR EACH ROW
-> BEGIN
-> DECLARE `done` BOOL DEFAULT FALSE;
-> DECLARE `_id` INT;
-> DECLARE `_value` VARCHAR(50);
->
-> DECLARE `demo_cursor` CURSOR FOR
-> SELECT * -- <- SELECT `id`, `value` Recommendation for use
-> FROM `tbl_demo`
-> WHERE `id` = NEW.`id`;
-> DECLARE CONTINUE HANDLER FOR NOT FOUND SET `done` := TRUE;
->
-> OPEN `demo_cursor`;
->
-> `read_loop`: LOOP
-> FETCH `demo_cursor` INTO `_id`, `_value`;
->
-> IF `done` THEN
-> CLOSE `demo_cursor`;
-> LEAVE `read_loop`;
-> END IF;
->
-> INSERT INTO `result_demo`
-> (`id`, `value`)
-> VALUES
-> (`_id`, `_value`);
-> END LOOP;
-> END//
我希望根据 NEW 字段值声明demo_cusror类似
if NEW.`id`=NULL THEN
DECLARE `demo_cursor` CURSOR FOR SELECT * tbl_demo ;
ELSE
DECLARE `demo_cursor` CURSOR FOR SELECT * tbl_demo2;
END IF
我试过了,但我不能在声明部分提出条件。
您不能在 mysql 中有条件地声明任何变量。时期。正如声明上的 mysql 文档所说:
声明只允许在开始...END 复合语句,并且必须位于其开头,在任何其他语句之前。
声明 2 个游标变量,并在应用程序逻辑中决定使用哪一个。