阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

MySQL存储过程定义中的特性(characteristic)的含义

143次阅读
没有评论

共计 2398 个字符,预计需要花费 6 分钟才能阅读完成。

MySQL 的存储过程蛮啰嗦的,与 MSSQL 或者 Oracle 的存储过程相比,如果没有显式指定,他会隐含地指定一系列特性(characteristic)的默认值来创建存储过程

MySQL 存储过程定义中的特性(characteristic)的含义

通常在使用图形界面工具进行存储过程编写的时候,图形界面工具会自动加上这部分内容比,
如用 HeidiSQL 创建存储过程的时候,会自动生成这些特性(characteristic)的默认值。
但是这些特性究竟是干啥的,有什么影响,一直没有怎么弄清楚。

MySQL 存储过程定义中的特性(characteristic)的含义

LANGUAGE SQL
存储过程语言,默认是 sql,说明存储过程中使用的是 sql 语言编写的,暂时只支持 sql,后续可能会支持其他语言

NOT DETERMINISTIC
是否确定性的输入就是确定性的输出,默认是 NOT DETERMINISTIC,只对于同样的输入,输出也是一样的,当前这个值还没有使用

CONTAINS SQL
提供子程序使用数据的内在信息,这些特征值目前提供给服务器,并没有根据这些特征值来约束过程实际使用数据的情况,说白了就是没有使用的
包括以下四种选择
1.CONTAINS SQL 表示子程序不包含读或者写数据的语句
2.NO SQL 表示子程序不包含 sql
3.READS SQL DATA 表示子程序包含读数据的语句,但是不包含写数据的语句
4.MODIFIES SQL DATA 表示子程序包含写数据的语句。

SQL SECURITY DEFINER
用来指定存储过程是使用创建者的许可来执行,还是执行者的许可来执行,默认值是 DEFINER
DEFINER 创建者的身份来调用,对于当前用户来说:如果执行存储过程的权限,且创建者有访问表的权限,当前用户可以成功执行过程的调用的
说白了就是当前用户调用存储过程,存储过程执行的具体操作是借助定义存储过程的 user 的权限执行的。
INVOKER 调用者的身份来执行,对于当前用户来说:如果执行存储过程的权限,以当前身份去访问表,如果当前身份没有访问表的权限,即便是有执行过程的权限,仍然是无法成功执行过程的调用的。
说白了就是当前用户调用存储过程,只有当前用户有执行存储过程中涉及的对象的操作的权限的时候,才能成功执行。

COMMENT ”
存储过程的注释性信息写在 COMMENT 里面,这里只能是单行文本,多行文本会被移除到回车换行等,一个字:扯
为什么说这个扯淡呢?
通常情况下,楼主会注释一个调用存储过程的示例在备注里,以免自己活着别人在调试的时候,参数很多的时候,可以很快调用起来,麻烦写半天参数之类的
— 因此就会存在类似如下的注释, 但是注释中的语句会被全部保存成一行,格式给抹掉了
/*
set @p_parameter1 = ‘abc’;
set @p_parameter2 = 200;
call mysql_procedure(@p_parameyter1,@p_parameter2)
*/

以下是一个存储过程的 demo,delimiter 仅仅是让存储过程知道,遇到 delimiter 定义的字符的时候是结束的标记。
话说 MySQL 不支持匿名块就算了,定义存储过程的时候,什么时候结束他自己都解析不出来?

delimiter KKKKKKKK(当然是 fuck 也行)

CREATE DEFINER=`root`@`%` PROCEDURE `porcedureName`(in p_parameter1 varchar(200),in p_parameter2 int,out p_outparameter int)

    — 存储过程语言,默认是 sql,说明存储过程中使用的是 sql 语言编写的,暂时只支持 sql,后续可能会支持其他语言
    LANGUAGE SQL
   
   
    — 是否确定性的输入就是确定性的输出,默认是 NOT DETERMINISTIC,只对于同样的输入,输出也是一样的,当前这个值还没有使用
    NOT DETERMINISTIC
   
   
    — 提供子程序使用数据的内在信息,这些特征值目前提供给服务器,并没有根据这些特征值来约束过程实际使用数据的情况,说白了就是没有使用的
    — ONTAINS SQL 表示子程序不包含读或者写数据的语句
    — NO SQL 表示子程序不包含 sql
    — READS SQL DATA 表示子程序包含读数据的语句,但是不包含写数据的语句
    — MODIFIES SQL DATA 表示子程序包含写数据的语句
    CONTAINS SQL
   
    — 用来指定存储过程是使用创建者的许可来执行,还是执行者的许可来执行,默认值是 DEFINER
    — DEFINER 创建者的身份来调用,如果创建者有权限访问存储过程中的表,调用者有执行过程的权限,就可以执行
    — INVOKER 调用者的身份来执行,取决于调用是否有执行过程 + 执行过程中 sql 语句对应的权限
    SQL SECURITY DEFINER
   
    — 存储过程的注释性信息写在 COMMENT 里面,这里只能是单行文本,多行文本会被移除到回车换行等,一个字:扯
    — 为什么说这个扯淡呢?
    — 通常情况下,楼主会注释一个调用存储过程的示例在备注里,以免自己活着别人在调试的时候,参数很多的时候,调用起来,麻烦写半天参数之类的
    — 因此就会存在类似如下的注释, 但是注释中的语句会被全部保存成一行,格式给抹掉了
    /*
    set @p_parameter1 = ‘abc’;
    set @p_parameter2 = 200;
    call mysql_procedure(@p_parameyter1,@p_parameter2)           
    */
    COMMENT ”
begin
    select * from user where id = 100;
end

KKKKKKKK(delimiter 是 fuck 的话,这里就是 fuck 了,结尾的标记而已)

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-11/148499.htm

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-22发表,共计2398字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中