文档首页 > > 常见问题> 操作类问题> MySQL迁移中Definer强制转化后如何维持原业务用户权限体系

MySQL迁移中Definer强制转化后如何维持原业务用户权限体系

分享
更新时间: 2019/10/29 GMT+08:00

Definer的使用主要应用在视图、存储过程、触发器、事件等对象里,Definer并不会限制对象被调用的权限,但会限制对象访问数据库的权限。本场景下,用户在MySQL迁移过程中选择了“所有Definer迁移到该用户下”,则源库用户体系下其他用户账号在完成用户迁移后,如果用户迁移和权限授权都执行成功,则无需授权便可继续使用原业务(使用DRS用户迁移功能可以实现用户、权限、密码迁移),否则如果想在原来的用户权限体系下延用原业务,则需要进行授权后才具有Definer相关数据库对象的访问使用权限,从而保证原业务正常。

本章节主要介绍如何通过数据库命令行对用户账号进行授权的方法。

  1. 确保新用户(Definer统一使用指定账号)具备足够的权限执行视图、存储过程等相关SQL。
  2. 通过MySQL官方客户端或者其它工具登录目标数据库。
  3. 通过如下命令查看需要授权的用户user当前权限详情。

    show grants for  'user'@'host';

  4. 为了保证原业务不报错,使用如下命令给用户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';

  5. 使用授权后的用户账号访问目标库对象,无异常报错表示授权成功。需要注意:在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';

分享:

文档是否有解决您的问题?

提交成功!

非常感谢您的反馈,我们会继续努力做到更好!

反馈提交失败,请稍后再试!

*必选

请至少选择或填写一项反馈信息

字符长度不能超过200

提交反馈 取消

如您有其它疑问,您也可以通过华为云社区问答频道来与我们联系探讨

跳转到云社区