存储过程中definer和invoker

来源:互联网 发布:win10磁盘整理软件 编辑:程序博客网 时间:2024/06/09 14:01

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

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

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

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

原创粉丝点击