在创建 MySQL 存储过程时是否需要 `definer`?


否,在创建存储过程时,`definer` 部分不是强制性的。在您想要创建定义符时使用它。

从 MySQL.user 表中检查所有用户和主机 −

mysql> select user,host from mysql.user;

以下是输出 −

+------------------+-----------+
| user             | host      |
+------------------+-----------+
| Manish           | %         |
| User2            | %         |
| mysql.infoschema | %         |
| mysql.session    | %         |
| mysql.sys        | %         |
| root             | %         |
| Adam Smith       | localhost |
| User1            | localhost |
| am               | localhost |
+------------------+-----------+
9 rows in set (0.03 sec)

在此,让我们创建一个定义符,即 Adam Smith。创建存储过程的查询如下 −

mysql> delimiter //
mysql> CREATE DEFINER = 'Adam Smith'@'localhost' procedure Sp_Definer()
   -> begin
   -> select 'Hello MySQL';
   -> end;
   -> //
Query OK, 0 rows affected (0.14 sec)
mysql> delimiter ;

使用 CALL 命令调用存储过程。语法如下 −

CALL yourStoredProcedureName();

调用上述存储过程。

mysql> call Sp_Definer();

以下是输出。

+-------------+
| Hello MySQL |
+-------------+
| Hello MySQL |
+-------------+
1 row in set (0.00 sec)
Query OK, 0 rows affected (0.01 sec)

更新于: 30-6 月 -2020

1 千次 + 查看

开启您的 职业生涯

完成课程获得认证

立即开始
广告