本篇文章给大家分享的是有关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,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。