MySQL 存储过程-definer和invoker的解释

Posted 李小智

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL 存储过程-definer和invoker的解释相关的知识,希望对你有一定的参考价值。

【definer和invoker的解释】

    创建存储过程的时候可以指定 SQL SECURITY属性,设置为 DEFINER 或者INVOKER,用来奉告mysql在执行存储过程的时候,,是以DEFINER用户的权限来执行,还是以调用者的权限来执行。

   默认情况下,使用DEFINER方式,此时调用存储过程的用户必须有存储过程的EXECUTE权限,并且DEFINER指定的用户必须是在mysql.user表中存在的用户。

   DEFINER模式下,默认DEFINER=CURRENT_USER,在存储过程执行时,mysql会检查DEFINER定义的用户‘user_name‘@‘host_name‘的权限;

   INVOKER模式下,在存储过程执行时,会检查存储过程调用者的权限。

以上是关于MySQL 存储过程-definer和invoker的解释的主要内容,如果未能解决你的问题,请参考以下文章

MySQL中的定义者(definer)的作用

创建 MySQL 存储过程时,如何避免使用不断变化的 ip 设置 DEFINER?

mysql 存储过程,函数,触发器

MySql 存储过程及调用方法

mysql 中的存储过程

mysql 存储过程