MySQL笔记-procedure与function

一、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型参数,传递的是值,内部的改变对外部无影响。


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

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值