无论用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授予的权限会覆盖其他所有级别的相同权限设置。