zoukankan      html  css  js  c++  java
  • mysql 执行函数时出现权限问题

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

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

     

    3、了解一下

    【definer和invoker的解释】

        创建存储过程的时候可以指定 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

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

  • 相关阅读:
    [BZOJ2431] [HAOI2009]逆序对数列
    [Luogu2323] [HNOI2006]公路修建问题
    [Luogu2455] [SDOI2006]线性方程组
    [BZOJ3550] [Sdoi2014]数数
    [Noip2017] 列队
    [Luogu2824] [HEOI2016/TJOI2016]排序
    [BZOJ1060] [ZJOI2007]时态同步
    P1036 选数 题解
    快速幂取模算法详解
    同余定理及其应用
  • 原文地址:https://www.cnblogs.com/xiaoyu1994/p/11051931.html
Copyright © 2011-2022 走看看