一、权限相关:

1.修改sql security 

Sql代码

ALTER PROCEDURE www SQL SECURITY INVOKER ;

ALTER PROCEDURE www SQL SECURITY DEFINER ;

(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 PROCEDURE test.* TO 'wtc'@'%';

GRANT CREATE ROUTINE,ALTER ROUTINE, SELECT,CREATE, INSERT, UPDATE, DELETE, EXECUTE  ON test.* TO 'wtc'@'%' IDENTIFIED BY '111111'

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

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

二、实验:

session 1:

mysql> show grants for ly@'%';

| Grants for ly@%

| GRANT USAGE ON *.* TO 'ly'@'%' IDENTIFIED BY PASSWORD '*23AE809DDACAF96AF0FD78ED04B6A265E05AA257'

mysql> show create procedure hhl.pr_param_in\G

*************************** 1. row ***************************

Procedure: pr_param_in

sql_mode:

Create Procedure: CREATE DEFINER=`root`@`localhost` PROCEDURE `pr_param_in`(

in id int

)

SQL SECURITY DEFINER

begin

INSERT INTO hhl.t  VALUES(1,'hhl');

end

character_set_client: latin1

collation_connection: latin1_swedish_ci

Database Collation: utf8_general_ci

1 row in set (0.00 sec)

grant  execute on procedure  hhl.pr_param_in to 'ly'@'%';

session 2:

mysql  -uly -p123 -h 1.1.1.5

mysql> call hhl.pr_param_in(1);

Query OK, 1 row affected (0.00 sec)

上面 SQL SECURITY=DEFINER,ly 用户调用存储过程是以DEFINER=`root`@`localhost`,即检查调用者ly是否具有存储过程的execute权限和DEFINER用户(`root`@`localhost`)是否具有存储过程引用的相关对象的权限.

*如果SQL SECURITY =INVOKER

session 1 :

mysql> ALTER PROCEDURE hhl.pr_param_in  SQL SECURITY INVOKER;

Query OK, 0 rows affected (0.00 sec)

mysql> show create procedure hhl.pr_param_in\G

*************************** 1. row ***************************

Procedure: pr_param_in

sql_mode:

Create Procedure: CREATE DEFINER=`root`@`localhost` PROCEDURE `pr_param_in`(

in id int

)

SQL SECURITY INVOKER

begin

INSERT INTO hhl.t  VALUES(1,'hhl');

end

character_set_client: latin1

collation_connection: latin1_swedish_ci

Database Collation: utf8_general_ci

1 row in set (0.00 sec)

session 2 :

mysql> call hhl.pr_param_in(1);

ERROR 1142 (42000): INSERT command denied to user 'ly'@'node5' for table 't'

上面 SQL SECURITY=INVOKERly 用户调用存储过程,即检查ly是否具有存储过程的execute权限和是否有存储过程引用的相关对象的权限. ly 用户确实没有对 hhl 库下的t 表insert权限。

转载于:https://blog.51cto.com/huanghualiang/1216786

MySQL存储过程权限检查主要点相关推荐

  1. mysql 绕过权限检查_跳过权限检查,强制修改mysql密码

    windows: 1,停止MYSQL服务,CMD打开DOS窗口,输入 net stop mysql 2,在CMD命令行窗口,进入MYSQL安装目录 比如E:\Program Files\MySQL\M ...

  2. mysql 存储过程改用户_Mysql修改存储过程相关权限问题

    在使用mysql数据库经常都会遇到这么一个问题,其它用户定义的存储过程,现在使用另一个用户却无法修改或者删除等:正常情况下存储过程的定义者对它有修改.删除的权限:但是其它的用户就要相于的授权,不然无法 ...

  3. jdbc mysql 存储过程执行失败_JDBC连接执行MySQL存储过程报空指针或权限错误

    JDBC连接执行MySQL存储过程报空指针或权限错误 最近使用root用户编写了几个存储过程,但是使用普通用户通过JDBC连接执行却报错: java.lang.NullPointerException ...

  4. mysql创建存储过程权限问题

    首先,在mysql存储过程出现的同时,用户权限也增加了5种,其中和存储过程有关的权限有 三种: ALTER ROUTINE 编辑或删除存储过程 CREATE ROUTINE 建立存储过程 EXECUT ...

  5. mysql 存储过程 on_MySQL存储过程的权限问题小结

    MySQL的存储过程,没错,看起来好生僻的使用场景.问题源于一个开发同学提交了权限申请的工单,需要开通一些权限. 本来是一个很正常的操作,但在我来看是比较着急且紧迫的,说来惭愧,忙着方向规划和开发的事 ...

  6. MYSQL存储过程梳理

    目录 事件调度器 事件任务 存储过程 错误处理 MySQL  存储过程 if语句 MySQL IF语句语法 MySQL IF ELSE语句 MySQL IF ELSEIF ELSE语句 MySQL I ...

  7. MySQL存储过程详解

    1.      存储过程简介   我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储 ...

  8. MySQL存储过程详解 mysql 存储过程

    mysql存储过程详解 1.      存储过程简介   我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的S ...

  9. mysql存储过程详解[转]

    mysql存储过程详解[转] 1.      存储过程简介   我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功 ...

最新文章

  1. linux下的jsp
  2. 剪映导出帧率选多少_剪映帧率怎么设置?剪映帧率设置方法
  3. springboot异步注解_SpringBoot如何实现异步、定时任务?
  4. 每天一道LeetCode-----找到序列中第一个没有出现的正整数,要求时间复杂度是O(n),空间复杂度是O(1)
  5. Python之List和Tuple类型(入门3)
  6. QML笔记-使用connect界面数据交互(qml中Designer使用)
  7. LVS原理详解及部署之四:keepalived介绍
  8. NetAug(网络增强)—Dropout的反面
  9. webpack4升级指南
  10. 1024程序员:算法仓鼠创业
  11. ucla 计算机专业 本科申请,2020年加州大学洛杉矶分校本科专业设置
  12. Google 回归中国,你准备好成为 Googler 了吗?
  13. 如何在Android设备上识别读取美国驾照信息
  14. ImageButton点击替换背景再次点击显示默认图片
  15. axure中备注线_除了香烟拆封线,防伪线的应用行业还有哪些?
  16. visionpro的无脚本和高级脚本(你要偷偷的卷,然后惊艳所有人)
  17. 旧佳人的伤感非主流空间心情日志发布:想念,是一种忧伤的幸福
  18. 读书笔记:《冯唐成事心法》
  19. JDBC编程(JDBC的使用)
  20. ABC人工蜂群算法求解函数优化实例C++(2020.11.5)

热门文章

  1. Java生鲜电商平台-订单中心服务架构与异常订单逻辑
  2. 记录一次查询log的经历
  3. [BZOJ4698][SDOI2008]Sandy的卡片(后缀自动机)
  4. 10.13 上午 考试
  5. weka 初练之 文本分类
  6. Spark RDD/Core 编程 API入门系列 之rdd实战(rdd基本操作实战及transformation和action流程图)(源码)(三)...
  7. 58.贪心算法练习:  最小新整数
  8. Test live writer
  9. iOS运行时-使用Runtime向Category中添加属性以及运行时介绍
  10. SSD硬盘 全盘安全擦除