mysql securitytype_mysql存储过程权限管理

查看存储过程:

方法一:

select `name` from mysql.proc where db = 'your_db_name' and `type`

= 'PROCEDURE'

方法二:

show procedure status;

1.修改mysql

存储过程的definer

修改mysql.proc表 的definer字段

Sql代码

update mysql.proc set definer='author@%'

update mysql.proc set security_type='INVOKER' where db='MC';

UPDATE `mysql`.`proc` SET `definer`='author%' WHERE `db`='test' AND

`name`='proc_name' AND `type`='PROCEDURE';

UPDATE `mysql`.`proc` SET `definer`='xuzhijing@%' WHERE

`db`='myDB'

AND `type`='PROCEDURE';

update mysql.proc set definer='root@%' where

db='myDb';

UPDATE `mysql`.`proc` SET `definer`='root00@%' WHERE

`db`='test' AND `name`='jjjj' AND `type`='PROCEDURE';

UPDATE `mysql`.`proc` SET `definer`='wtc_678869@%'

WHERE `db`='myDB' AND `type`='PROCEDURE';

2.修改security_type

Sql代码

update mysql.proc set security_type='INVOKER' where db='myDB';

(1)MySQL存储过程是通过指定SQL SECURITY子句指定执行存储过程的实际用户;

(2)如果SQL

SECURITY子句指定为DEFINER,存储过程将使用存储过程的DEFINER执行存储过程,验证调用存储过程的用户是否具有存储过程的execute权限和DEFINER用户是否具有存储过程引用的相关对象的权限;

(3)如果SQL

SECURITY子句指定为INVOKER,那么MySQL将使用当前调用存储过程的用户执行此过程,并验证用户是否具有存储过程的execute权限和存储过程引用的相关对象的权限;

(4)如果不显示的指定SQL SECURITY子句,MySQL默认将以DEFINER执行存储过程。

3.执行存储过程授权

Sql代码

GRANT EXECUTE ON test.* TO 'xuzhijing'@'%';

GRANT CREATE ROUTINE,ALTER ROUTINE, SELECT,CREATE, INSERT,

UPDATE, DELETE, EXECUTE ON test.* TO 'xuzhijing'@'%' IDENTIFIED BY

'111111'

GRANT EXECUTE ON test.* TO 'xuzhijing'@'%';

GRANT CREATE ROUTINE,ALTER ROUTINE, SELECT,CREATE, INSERT,

UPDATE, DELETE, EXECUTE ON test.* TO 'xuzhijing'@'%' IDENTIFIED BY

'111111'

CREATE ROUTINE : 创建存储过程的权限

ALTER ROUTINE : 修改存储过程的权限

4.删除用户

REVOKE all ON test.* FROM xuzhijing@'%'

DELETE FROM user WHERE User='user_name' and Host='host_name';

FLUSH PRIVILEGES;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值