在触发器中打印声明的变量

时间:2017-10-26 15:51:06

标签: mysql sql database rdbms database-trigger

我想计算每个插入的语句和显示后插入的元组数,有没有可能的方法来完成它?

代码:

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):不允许从触发器返回结果集

1 个答案:

答案 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 |
+-----------+