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

Print a declared variable in 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):不允许 return 来自触发器的结果集

更简单的方法是在 INSERT 完成后计算 "rows affected"。

每个 MySQL API 都应该有一个方法。例如 PHP 的 PDOStatement::rowCount(). Even if you are running the INSERT from an SQL script or a stored procedure, you can use the MySQL built-in function 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;

(请注意,像这样的单语句触发器不需要 begin/end 块,因此您无需费心更改语句分隔符。)

在执行插入之前初始化会话变量。然后在你插入之后,它应该有计数。

mysql> set @count_it = 0;

mysql> insert into employee (name) values ('harry'), ('ron'), ('hermione');

mysql> select @count_it;
+-----------+
| @count_it |
+-----------+
|         3 |
+-----------+