mysql 执行函数时出现权限问题

一、刚来新公司,因mysql版本陈旧,因此升级版本为5.6,升级导入数据后应用一直被报错以下html

二、各类问题排查后,终于找到问题,原来是mysql建立语句中加入 DEFINER 参数mysql

 

三、了解一下sql

【definer和invoker的解释】函数

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

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

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

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

四、解决方式:it

 给“@%”添加权限,或者重构函数语句将“@%”删除便可io

五、另外记录一点,当主机内存不足以被mysql分配内存时,后出现以下报错:

  InnoDB: mmap(274726912 bytes) failed; errno 12
  2019-06-19 11:38:34 13132 [ERROR] InnoDB: Cannot allocate memory for the buffer pool
  2019-06-19 11:38:34 13132 [ERROR] Plugin 'InnoDB' init function returned error.
  2019-06-19 11:38:34 13132 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
  2019-06-19 11:38:34 13132 [ERROR] Unknown/unsupported storage engine: InnoDB
  2019-06-19 11:38:34 13132 [ERROR] Aborting

  须要将服务其内存调大后才能继续使用

相关文章
相关标签/搜索