MySQL笔记-procedure与function

一、mysql5.6 文档关于procedure与function的创建语法图

MySQL笔记-procedure与function_第1张图片

图1

二、基础知识

1、delimiter指令

英文含义:分隔符,定界符。在mysql的命令行操作中的作用:指定一个符号为一条SQL 语句的结束,默认为分号。一条SQL语句结束时会立即执行,而procedure与function中存在分号,所以定义procedure与function之前,需要先修改此符号。如:delimiter //。见图2。

2、mysql中变量

在cmd窗口中,变量名为‘@xxx’形式,不需声明,可直接使用,默认值为NULL(但procedure或函数中的局部变量名不带@,且需要声明,格式:declare 变量名 datatype。但procedure或函数等结构体中也能直接使用'@xxx'形式的变量,且可在外部访问到)。见图2。

细节参考日志:Mysql中的变量类别

3、mysql中SET指令

对变量进行赋值,见图2。

MySQL笔记-procedure与function_第2张图片

图2


三、procedure简单创建与使用

如图:查询给定id对应的name值

MySQL笔记-procedure与function_第3张图片

说明:

1、红线标记第一处,使用INTO 函数将查询结果放在了输出参数中。如果是数值型数据,通过set指令直接赋值即可。若不用INTO ,将直接显示查询结果。

2、红线标记第二处,变量不同于普通的参数列表,@result是OUT的参数,所以并不会被释放,相当于一个引用。

3、标准语法中的:[DEFINER = { user | CURRENT_USER }]可选属性与routine_body必选属性,上面示例没有设置。routine_body即路由信息,格式为:数据库名.此procedure名,不填时为指定值:当前数据库.该procedure名。

4、call命令,调用函数或过程。


四、查看或删除procedure与function

查看当前数据库所有过程或函数:SHOW procedure/function STATUS;

查看某个过程或函数定义细节:SHOW CREATE procedure/function 进程名/函数名

删除某个过程或函数:DROP procedure/function 进程名/函数名


五、function函数简单实践

如图:编写函数实现两个数相加

MySQL笔记-procedure与function_第4张图片

说明:

1、创建格式与创建procedure大致相同,但多了个returns 与return,如果语句较少,可不用begin...end,returns语句后直接return。

2、对函数,参数只能为IN,所以可省略。对procedure同理,只要为IN 类型,都可以省略。对于IN型参数,传递的是值,内部的改变对外部无影响。


上面都只是在命令行创建的,如何在代码中创建?有空再看。

你可能感兴趣的:(数据库)