更新时间:2024-11-26 gmt 08:00
mysql迁移中definer强制转化后如何维持原业务用户权限体系-九游平台
definer的使用主要应用在视图、存储过程、触发器、事件等对象里,definer并不会限制对象被调用的权限,但会限制对象访问数据库的权限。本场景下,用户在mysql迁移过程中选择了“所有definer迁移到该用户下”,则源库用户体系下其他用户账号在完成用户迁移后,如果用户迁移和权限授权都执行成功,则无需授权便可继续使用原业务(使用drs用户迁移功能可以实现用户、权限、密码迁移),否则如果想在原来的用户权限体系下沿用原业务,则需要进行授权后才具有definer相关数据库对象的访问使用权限,从而保证原业务正常。
本章节主要介绍如何通过数据库命令行对用户账号进行授权的方法。
- 确保新用户(definer统一使用指定账号)具备足够的权限执行视图、存储过程等相关sql。
- 通过mysql官方客户端或者其它工具登录目标数据库。
- 通过如下命令查看需要授权的用户user当前权限详情。
show grants for 'user'@'host';
- 为了保证原业务不报错,使用如下命令给用户user授予涉及的数据库对象缺失的操作权限。
grant select,insert,update,delete on db_name.* to 'user'@'host';
一般情况下,访问数据库的权限包括:select、create、drop、delete、insert、update、index、event、create view、create routine、trigger、execute。您需要根据具体的数据库对象查看缺少哪些权限,再进行授权操作。
对于存储过程和函数,必须保证用户user对其有拥有execute权限,授权sql命令如下:
grant execute on db_name.function_name to 'user'@'host';
- 使用授权后的用户账号访问目标库对象,无异常报错表示授权成功。需要注意:在java项目工程中调用存储过程、函数如果出现 java.sql.sqlexception: user does not have access to metadata required to determine stored procedure parameter types. if rights can not be granted, configure connection with "noaccesstoprocedurebodies=true" to have driver generate parameters that represent inout strings irregardless of actual parametertypes,则需要单独执行用户user对mysql.proc库的授权:
grant select on mysql.proc to 'user'@'host';
父主题:
相关文档
意见反馈
文档内容是否对您有帮助?
提交成功!非常感谢您的反馈,我们会继续努力做到更好!
您可在查看反馈及问题处理状态。
系统繁忙,请稍后重试
如您有其它疑问,您也可以通过华为云社区问答频道来与我们联系探讨