【Mysql】修改definer

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

修改definer

本文介绍如何修改MySQL中的function、procedure、event、view和trigger的definer

修改function、procedure的definer

首先我们需要登录MySQL命令行界面然后执行以下命令

select definer from mysql.proc;

这个命令会列出所有的function和procedure同时显示它们的definer。如果要修改definer可以执行以下命令

update mysql.proc set definer='user@localhost';

其中user@localhost可以是任何合法的用户名和主机名表示只有这个用户才能访问数据库。

修改event的definer

如果要修改event的definer可以执行以下命令

select DEFINER from mysql.EVENT;

这个命令会列出所有的event并显示它们的definer。如果要修改definer可以执行以下命令

update mysql.EVENT set definer='user@localhost';

修改view的definer

如果要修改view的definer可以使用以下命令

select DEFINER from information_schema.VIEWS;

如果只是想查询指定的数据库的需要加一个条件

select DEFINER from information_schema.VIEWS table_schema = 'test_rex';

这个命令会列出所有的view并显示它们的definer。如果要修改definer可以执行以下命令

select concat("alter DEFINER=`user`@`localhost` SQL SECURITY DEFINER VIEW ", TABLE_SCHEMA, ".", TABLE_NAME, " as ", VIEW_DEFINITION, ";") from information_schema.VIEWS where DEFINER = 'user@localhost';

这个命令会查询出需要修改的VIEW并生成修改语句如下所示

alter DEFINER=`user`@`localhost` SQL SECURITY DEFINER VIEW mydb.myview as select * from mytable;

执行这条修改语句即可完成修改。
这里有一个细节需要注意下就是我第一次写成了如下结果mysql会自动再拼接上@%导致结果是吧definer改成了 user@localhost@%

alter DEFINER='user@localhost' SQL SECURITY DEFINER VIEW mydb.myview as select * from mytable;

修改trigger的definer

目前还没有找到具体方便的方法来修改trigger的definer。可以借助工具端如HeidiSQL、sqlyog等来一个个修改。需要注意的是在修改trigger的definer之前需要先锁表以避免在修改过程中出现数据不一致的情况。

总结

本文介绍了如何修改MySQL中的function、procedure、event、view和trigger的definer。通过修改definer您可以更好地控制数据库的访问权限保证数据库的安全性。需要注意的是在修改definer之前需要先备份数据以防修改出现错误。同时在执行修改操作时也需要谨慎操作以免造成不可逆的损失。

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: mysql