我想计算每个插入的语句和显示后插入的元组数,有没有可能的方法来完成它?
代码:
mysql> create trigger count_inserted_trigger
-> after insert on employee
-> for each row
-> begin
-> declare count_it int;
-> set count_it = 0;
-> set count_it = count_it + 1;
-> select count_it;
-> end;
-> $$
错误:
错误1415(0A000):不允许从触发器返回结果集
答案 0 :(得分:2)
更简单的方法是在INSERT完成后计算“受影响的行”。
每个MySQL API都应该有一个方法。例如PHP的PDOStatement::rowCount()。即使您从SQL脚本或存储过程运行INSERT,也可以使用MySQL内置函数ROW_COUNT()。
mysql> insert into employee (name) values ('harry'), ('ron'), ('hermione');
mysql> select row_count();
+-------------+
| row_count() |
+-------------+
| 3 |
+-------------+
但是要回答你的问题,你可以做你只想用会话变量做的事情,而不是触发器中声明的局部变量。局部变量是触发器的每个调用的本地变量,每行一次。所以它不能将其值从一行保留到下一行。而会话变量的范围限定为当前会话。您可以在触发器中设置会话变量,并且在触发器完成后,该值仍将保留在该变量中。
mysql> create trigger count_inserted_trigger
after insert on employee
for each row
set @count_it = @count_it + 1;
(请注意,像这样的单语句触发器不需要开始/结束块,因此您不需要改变语句分隔符。)
在执行插入之前初始化会话变量。插入后,它应该有计数。
mysql> set @count_it = 0;
mysql> insert into employee (name) values ('harry'), ('ron'), ('hermione');
mysql> select @count_it;
+-----------+
| @count_it |
+-----------+
| 3 |
+-----------+