2018-03-02存储过程definer
2018-03-02 16:43
218 查看
导入的另一个库的数据库到开发环境来做测试,发现存储过程在程序调用的时候出错,显示没有该存储过程。但是查看库里面存储过程是导入了的。show procedure status; 查看所有存储过程如下图:
后来查看 存储过程,如上 toll_cc 库,里面的definer 定义的是appACCPayor,而我的数据库用户里面没有该用户。下面可以看看存储过程中该字段的意义:我们在mysql创建view、trigger、function、procedure、event时都会定义一个Definer=‘xxx’如下是引用网上网友总结:
【definer和invoker的解释】 创建存储过程的时候可以指定 SQL SECURITY属性,设置为 DEFINER 或者INVOKER,用来奉告mysql在执行存储过程的时候,,是以DEFINER用户的权限来执行,还是以调用者的权限来执行。 默认情况下,使用DEFINER方式,此时调用存储过程的用户必须有存储过程的EXECUTE权限,并且DEFINER指定的用户必须是在mysql.user表中存在的用户。 DEFINER模式下,默认DEFINER=CURRENT_USER,在存储过程执行时,mysql会检查DEFINER定义的用户'user_name'@'host_name'的权限; INVOKER模式下,在存储过程执行时,会检查存储过程调用者的权限。
修改存储过程的definer 就可以了update mysql.proc set definer='root@%' where db='toll_cc' and name='get_sequence_number';
修改后就能正常使用存储过程了。
后来查看 存储过程,如上 toll_cc 库,里面的definer 定义的是appACCPayor,而我的数据库用户里面没有该用户。下面可以看看存储过程中该字段的意义:我们在mysql创建view、trigger、function、procedure、event时都会定义一个Definer=‘xxx’如下是引用网上网友总结:
【definer和invoker的解释】 创建存储过程的时候可以指定 SQL SECURITY属性,设置为 DEFINER 或者INVOKER,用来奉告mysql在执行存储过程的时候,,是以DEFINER用户的权限来执行,还是以调用者的权限来执行。 默认情况下,使用DEFINER方式,此时调用存储过程的用户必须有存储过程的EXECUTE权限,并且DEFINER指定的用户必须是在mysql.user表中存在的用户。 DEFINER模式下,默认DEFINER=CURRENT_USER,在存储过程执行时,mysql会检查DEFINER定义的用户'user_name'@'host_name'的权限; INVOKER模式下,在存储过程执行时,会检查存储过程调用者的权限。
修改存储过程的definer 就可以了update mysql.proc set definer='root@%' where db='toll_cc' and name='get_sequence_number';
修改后就能正常使用存储过程了。
相关文章推荐
- MySQL存储过程
- ASP程序与SQL存储过程结合使用详解
- Oracle存储过程之数据库中获取数据实例
- oracle中存储函数与存储过程的区别介绍
- MSSQL自身存储过程的一个注入漏洞
- SQL SERVER调用存储过程小结
- SQLServer 2005 列所有存储过程的语句
- SQLServer 2008中的代码安全(一) 存储过程加密与安全上下文
- SQL2005重新生成索引的的存储过程 sp_rebuild
- SQL Server存储过程的基础说明
- sqlserver存储过程语法详解
- MSSQL事务的存储过程
- SQL Server 存储过程解析
- sql server动态存储过程按日期保存数据示例
- SQL Server中数据行批量插入脚本的存储实现
- SQLserver 数据库危险存储过程删除与恢复方法
- SQL Server存储过程中使用表值作为输入参数示例
- SQL Server存储过程同时返回分页结果集和总数
- Sql存储过程游标循环的用法及sql如何使用cursor写一个简单的循环