1、刚来新公司,因mysql版本陈旧,所以升级版本为5.6,升级导入数据后应用一直被报错如下
2、各种问题排查后,终于找到问题,原来是mysql创建语句中加入 DEFINER 参数
3、了解一下
创建存储过程的时候可以指定 SQL SECURITY属性,设置为 DEFINER 或者INVOKER,用来奉告mysql在执行存储过程的时候,,是以DEFINER用户的权限来执行,还是以调用者的权限来执行。
默认情况下,使用DEFINER方式,此时调用存储过程的用户必须有存储过程的EXECUTE权限,并且DEFINER指定的用户必须是在mysql.user表中存在的用户。
DEFINER模式下,默认DEFINER=CURRENT_USER,在存储过程执行时,mysql会检查DEFINER定义的用户’user_name’@’host_name’的权限;
INVOKER模式下,在存储过程执行时,会检查存储过程调用者的权限。
4、解决方式:
给“@%”添加权限,或者重构函数语句将“@%”删除即可
5、另外记录一点,当主机内存不足以被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
需要将服务其内存调大后才能继续使用
1. 本站所有资源来源于用户上传和网络,如有侵权请及时联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,默认解压密码为"mababa.xin",如遇到无法解压的请联系管理员!
码巴巴-优质代码创造者 » mysql 执行函数时出现权限问题
常见问题FAQ
- 免费下载或者VIP会员专享资源能否直接商用?
- 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
- 提示下载完但解压或打开不了?
- 找不到素材资源介绍文章里的示例图片?
- 一个高级程序员模板开发平台