`

不能查看别人创建的存储过程的DDL

阅读更多

无论用navicat还是命令行show create  procedure 都不能查看到存储过程的定义语句。检查权限,对数据库已有

 SELECT, UPDATE, CREATE TEMPORARY TABLES, EXECUTE, CREATE VIEW, SHOW VIEW, CREATE ROUTINE, ALTER ROUTINE这些权限,

其中上面最后两个是关于stored procedure,function,trigger的。

 

 

mysql> select version();
+------------+
| version()  |
+------------+
| 5.1.52-log |
+------------+
1 row in set (0.04 sec)

 

        然后找到http://stackoverflow.com/questions/1084268/i-cant-see-sql-queries-in-mysql-stored-procedure ,

提示要有mysql.proc的Select权限,进而查询自己的权限列表: show grants fro 'zzz'@'%';

在全局的权限中,仅有如下:  GRANT CREATE ROUTINE, ALTER ROUTINE ON *.* TO 'zzz'@'%' IDENTIFIED BY PASSWORD '*xxxxxxxxxxxxxxx' WITH MAX_USER_CONNECTIONS 6 .

 

       最后,同事赋予了全局的Select权限就解决问题了。

 

       最后记录一下mysql权限的五个级别:

  • Global Level
  • Database Level
  • Table Level
  • Column Level
  • Routine Level

        其中,Global Level授予的权限会覆盖其他所有级别的相同权限设置。

 

0
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics