在触发器中打印声明的变量
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 |
+-----------+
我想统计每条插入语句后插入的元组数并显示,有什么方法可以实现吗?
代码:
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 |
+-----------+