一、mysql5.6 文档关于procedure与function的创建语法图
图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。
图2
三、procedure简单创建与使用
如图:查询给定id对应的name值
说明:
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函数简单实践
如图:编写函数实现两个数相加
说明:
1、创建格式与创建procedure大致相同,但多了个returns 与return,如果语句较少,可不用begin...end,returns语句后直接return。
2、对函数,参数只能为IN,所以可省略。对procedure同理,只要为IN 类型,都可以省略。对于IN型参数,传递的是值,内部的改变对外部无影响。
上面都只是在命令行创建的,如何在代码中创建?有空再看。