mysql中怎么修改所有的definer
本篇文章给大家分享的是有关mysql中怎么修改所有的definer,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
mysql中的definer是什么,有什么作用?
先授权一个:grantallontestdb.*to'user1'@'%'identifiedby'000000'withgrantoption;然后我们创建一个存储过程如下:
USE`testdb`;
DROPprocedureIFEXISTS`user_count`;DELIMITER$$
USE`testdb`$$
CREATEDEFINER=`root`@`%`PROCEDURE`user_count`()LANGUAGESQLNOTDETERMINISTICCONTAINSSQLSQLSECURITYINVOKERCOMMENT''BEGINselectcount(*)frommysql.user;END$$DELIMITER;
用root帐号登陆:
mysql>usetestdb;
Databasechangedmysql>calluser_count();
+----------+|count(*)|+----------+|3|+----------+1rowinset(0.00sec)QueryOK,0rowsaffected(0.00sec)可以正常查询出来。我们再用user1进行登陆:mysql>usetestdb;
Databasechangedmysql>calluser_count();ERROR1142(42000):SELECTcommanddeniedtouser'user1'@'localhost'fortable'user'
发现系统报错查询不到了,这是因为我们在上述定义的SQL SECURITY值为INVOKER,存储过程执行过程中会以user1具有的权限来执行,其中调用到了mysql的库,而我们的user1帐户只有testdb库的使用权限,所以会返回失败。
如果方便修改mysql中所有已经定义到的definer?
现在在mysql涉及的definer有view、trigger、function、procedure、event。我们一个个作介绍。
1.修改function、procedure的definer
update mysql.proc set definer='user@localhost'; -- 如果有限定库或其它可以加上where条件
4.修改trigger的definer
Flush tables with readlock
<p align="left" font-size:14px;white-space:normal;background-color:#ffffff;"="">Unlock tables
以上就是mysql中怎么修改所有的definer,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。