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!

人工智能实验室
相关文章相关文章
  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

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

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...