CREATE TRIGGER ghxz BEFORE INSERT ON GH FOR EACH ROW BEGIN DECLARE rs VARCHAR(8); SELECT Gh_no INTO rs FROM inserted; IF rs >= 100 THEN SELECT * FROM brst; SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = '挂号人数超过最大限度'; ROLLBACK; END IF; END; 1415 - Not allowed to return a result set from a trigger
时间: 2023-06-14 18:06:35 浏览: 102
1GHXz雷鸟CPU超频经验谈.pdf
这个错误提示是因为在触发器中使用了SELECT语句返回了一个结果集,而触发器是不允许返回结果集的。因为触发器是在数据库操作之前或之后自动执行的,如果在触发器中返回结果集,可能会影响到数据库操作的正确性,因此MySQL禁止在触发器中使用SELECT语句返回结果集。
如果你需要在触发器中获取某些数据,可以使用变量来存储查询结果,而不是直接返回结果集。例如,你可以将查询结果存储在一个变量中,然后在触发器的其他操作中使用这个变量。下面是一个修改后的示例代码:
```
CREATE TRIGGER ghxz BEFORE INSERT ON GH FOR EACH ROW BEGIN
DECLARE rs VARCHAR(8);
SELECT Gh_no INTO rs FROM inserted;
DECLARE cnt INT;
SELECT COUNT(*) INTO cnt FROM brst;
IF rs >= 100 THEN
SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = '挂号人数超过最大限度';
ROLLBACK;
END IF;
END;
```
在这个修改后的代码中,我使用了一个变量cnt来存储brst表中的记录数,而不是直接返回结果集。如果你需要在触发器中执行其他操作,也可以使用类似的方式来获取数据。
阅读全文