mysql数据库存储过程与函数

  次阅读 来源:互联网(转载协议) 2016-01-27 15:41 我要评论(0)

存储过程

存储过程是一段代码,由存储在一个数据库的目录中、声明式的和过程式的sql语句组成,可以从一个程序、触发器或者另一个存储过程调用它从而激活它。

每个存储过程包含至少3部分:一个参数列表、一个存储过程、一个名字。

一个数据库中的存储过程的名字必须是唯一的,就像表的名字一样。

一个参数列表可以有0个、1个或多个参数,通过这些参数,过程就可以和外界联系。

存储过程支持3中参数类型:

1、输入参数IN:数据可以传递到存储过程;

2、输出参数OUT:数据可以由存储过程传到外界;

3、输入\输出参数INOUT:既可以充当输入参数,也可以充当输出参数。

就像c语言函数一样,即使没有参数,过程名后面还是需要跟一对括号。

存储过程以begin开始end结束,且之间还可以嵌套begin-end块。

局部变量:

declare 变量列表 变量类型 [default 默认值]

存储过程不仅可以使用局部变量,还可以使用全局变量。

默认值不仅限于直接量,还可以是符合表达式,也可以是标量子查询。

mysql> delimiter //

mysql> create procedure test (in a integer)

-> begin

-> declare b integer default

-> (select count(*) from student );

-> end

-> //

Query OK, 0 rows affected (0.42 sec)

set语句

set用于给一个变量赋值。如:

set a = 1;

set a := 1;

set a = 1,b := a;

leave语句

离开一个块(循环块或者语句块),类似于break;

如下,进入begin后立即离开。

mysql> create procedure test (in a integer)

-> block : begin

-> leave block;

-> end//

iterate语句

进入一个循环。

call语句

调用存储过程。

if-esle语句

格式:

if 条件 then 语句 ;

elseif 条件 then 语句;

esle 语句;

end if

mysql> create procedure test (in a integer)

-> begin

-> declare b integer;

-> if a < 60 then set b = -1;

-> elseif a >60 then set b = 1;

-> else set b = 0;

-> end if;

-> end

-> //

case语句

格式:

case

when 条件 then 语句;

when 条件 then 语句;

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 马云的新零售?张近东的智慧零售?抑或是刘强东的第四次零售革命?

    马云的新零售?张近东的智慧零售?抑或是刘强东的第四次零售革命?

  • 区块链最近太火,但A股多家公司明确表态不考虑涉足

    区块链最近太火,但A股多家公司明确表态不考虑涉足

  • 汤晓鸥:人工智能的中国式文艺复兴

    汤晓鸥:人工智能的中国式文艺复兴

  • 全球陷入"区块链狂热"潮,大规模应用还需等待

    全球陷入"区块链狂热"潮,大规模应用还需等待

网友点评网友点评
阅读推荐阅读推荐

算法 任何一个入门的软件开发人员都会听到这句话:算法是软件的灵魂!近年来大火的机器学习即是在算法在人工智能上的集中体现。今日头条通...

据《日本经济新闻》报道,日本东京大学教授稻叶雅幸等人开发出再现日本人骨骼肌肉构造的机器人。机器人各部位的肌肉和骨骼长度与日本人的平...

以奥黛丽-赫本为原型打造的人形机器人索菲娅首次拜访了印度。索菲娅是世界上首位获得公民身份的机器人,她在12月30日出现在了印度理工学院...

在查获现场,代售点电脑旁的一台机器人通过敲击电脑键盘抢票。 广州日报惠州讯 (全媒体记者秦仲阳 通讯员张中铃摄影报道)2018年春运售票已...