不灭的焱

革命尚未成功,同志仍须努力

作者:php-note.com  发布于:2020-02-06 20:39  分类:MySQL/NoSQL  编辑

注意:MySQL 中的 存储过程函数,统称为 routine (例程)

我一般的做法:统一用超级管理员 root 去新建 存储过程、函数、视图、事件等,即 definer 为 root,安全级别为definer,然后针对不同的数据库新建不同的MySQL访问账号,给它分配执行 存储过程、视图 等的权限。。。

MySQL 存储过程、函数 routine 权限

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

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存储过程权限检查主要点

MySQL中的 definer与 SQL Security

MySQL如何批量修改“视图(View)”的属主(definer)

MySQL如何修改“存储过程”的访问权限

MySQL如何修改所有的 definer

definer('root'@'%') does not exist

关于definer('root'@'%') does not exit解决办法