DELIMITER $$ CREATE TRIGGER jcxz BEFORE INSERT ON JC FOR EACH ROW BEGIN DECLARE rs VARCHAR(8); SELECT Jc_no INTO rs FROM JC WHERE Jc_no = NEW.Jc_no; IF rs >= 100 THEN SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = '检查人数超过最大限度'; ROLLBACK; END IF; END $$ DELIMITER ; 1422 - Explicit or implicit commit is not allowed in stored function or trigger.
时间: 2023-06-14 13:05:51 浏览: 219
这个错误是因为你在 trigger 中使用了 ROLLBACK,而 trigger 不允许显式或隐式的 COMMIT 或 ROLLBACK 操作。解决办法是将 ROLLBACK 操作移除,并在触发 SIGNAL 之后让 trigger 自然结束即可。例如:
```
DELIMITER $$
CREATE TRIGGER jcxz BEFORE INSERT ON JC
FOR EACH ROW
BEGIN
DECLARE rs VARCHAR(8);
SELECT Jc_no INTO rs FROM JC WHERE Jc_no = NEW.Jc_no;
IF rs >= 100 THEN
SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = '检查人数超过最大限度';
END IF;
END $$
DELIMITER ;
```
这样,当检查人数超过最大限度时,将触发 SIGNAL,但不会执行 ROLLBACK 操作。
相关问题
DELIMITER $$ CREATE TRIGGER ghxz AFTER INSERT ON GH FOR EACH ROW BEGIN DECLARE rs VARCHAR(8); SET rs = NEW.Gh_no; IF rs >= 100 THEN SELECT * FROM brst; SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = '挂号人数超过最大限度'; ROLLBACK; END IF; END $$ DELIMITER ; 1415 - Not allowed to return a result set from a trigger
触发器是在数据库的特定事件发生时自动执行的特殊存储过程。在 MySQL 中,触发器有两种类型:BEFORE 触发器和 AFTER 触发器。BEFORE 触发器在指定操作发生之前执行,因此可以用来验证数据的有效性。AFTER 触发器在指定操作发生之后执行,因此可以用来执行其他操作,例如更新其他表或发送电子邮件通知等。
然而,在触发器中返回结果集是不允许的,因为触发器的主要目的是在指定事件发生时自动执行某些操作,而不是返回数据。如果您需要返回数据,请考虑使用存储过程或函数。
在您的触发器中,您尝试从 SELECT 语句返回结果集,这是不允许的。如果您需要检查一个条件并防止插入操作,您可以使用 SIGNAL 语句生成一个错误,并使用 ROLLBACK 语句回滚插入操作。例如:
```
DELIMITER $$
CREATE TRIGGER ghxz
AFTER INSERT ON GH
FOR EACH ROW
BEGIN
DECLARE rs VARCHAR(8);
SET rs = NEW.Gh_no;
IF rs >= 100 THEN
SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = '挂号人数超过最大限度';
ROLLBACK;
END IF;
END $$
DELIMITER ;
```
这个触发器在插入每一行数据之后执行,如果 `Gh_no` 大于等于 100,则触发器将生成一个错误消息并回滚插入操作。请注意,这个触发器不会返回任何结果集。
解释一下这段代码:delimiter $$ create trigger insert_stu after insert on Student for each row begin declare @cid varchar(30); select @cid=Cid from inserted; update Class set Cnumber = Cnumber + 1 where Cid = @cid; end; $$ delimiter ;
这段代码是用于创建一个触发器 (trigger)。触发器是一种特殊的数据库对象,可以在数据库表中的数据发生变化时自动执行特定的操作。
具体来说,这个触发器的名称是 `insert_stu`,它会在 `Student` 表中插入一条记录之后自动触发。`for each row` 表示每插入一行记录就会触发一次该触发器。
在触发器的主体部分,首先声明了一个名为 `@cid` 的变量。这个变量是用来存储插入到 `Student` 表中的记录的 `Cid` 字段值。`declare` 表示声明变量,`varchar(30)` 表示该变量是一个长度为 30 的字符串类型。
接下来,使用 `select` 语句从 `inserted` 表中获取新插入的记录的 `Cid` 字段值,并将其赋值给 `@cid` 变量。`inserted` 是一个特殊的表,用于存储触发器所依赖的数据。在这个例子中,`inserted` 表中存储了新插入的 `Student` 记录的所有字段值。
最后,使用 `update` 语句更新 `Class` 表中的记录,将 `Cnumber` 字段的值增加 1。`where` 子句用于指定更新哪些记录,这里是根据 `Cid` 字段的值来匹配。这表示当向 `Student` 表中插入一条记录时,与该记录相关联的 `Class` 表中的 `Cnumber` 字段值都会自动加 1。
阅读全文