mysql函数和过程有什么区别_MySQL中函数和存储过程的用法与区别

存储过程是用户定义的一系列sql语句的集合,涉及特定表或其它对象的任务,用户可以调用存储过程,而函数通常是数据库已定义的方法,它接收参数并返回某种类型的值并且不涉及特定用户表。

函数

Mysql中函数有两种:

系统函数

自定义函数

在mysql中,函数必须有返回值: 所以凡是有结果的内容都是由select去访问

函数调用: select 函数名(参数列表);

一、系统函数

在mysql中所有的字符串操作单位基本都是字符

substring: 子字符串截取

06eeb2db6e2120f82305ff0a5ea5dbd9.png

char_length: 字符长度

length: 字节长度

82027e5f770654bd06c6155212f9910e.png

instr: 在什么里面

5f6a7003623586f1dca5ad302b3d8c96.png

lpad: 左填充: 将字符串填充到指定长度(字符数)

8c9d074556283c533d1c55bb8f4cbad8.png

insert: 字符串替换

7f75b22b15375febceae3ae85a9bfc8d.png

strcmp: 比较字符串

eecabc43d8604e685cc77a7b5c2dcb39.png

时间日期函数: now(), unix_timestamp()

f318aa9bf1aef51467beae75f541b62e.png

二、自定义函数

用户自己定义函数

函数要素: 关键字(function), 函数名, 参数列表(形参和实参), 返回值, 函数体

1. 定义函数

定义语法

create Function 函数名([形参列表]) returns返回值的数据类型begin

--函数体--return 返回值

end

a9fcd2470903d1d2228f39c02bb9deab.png

2. 查看函数

函数不能像表一样查看: 但是可以查看函数创建语句: show create function 函数名;

29b36d5f0aed75475ce73ea76f8025b4.png

函数有另外一种方式查看所有函数: show function status like ‘pattern’;

b205af133638da0415cbee678814b9d1.png

3. 删除函数

drop function 函数名;

f3e11333e2f08b3ba096f1a7135caeaf.png

4. 调用函数

与调用系统函数一样

cc4d6a2009519ba2337e17101aa510bc.png

虚拟表: dual,为了保证select的语法结构性而存在的一个虚拟表

select 1+ 1 from dual;

7119a410e388bb424436354209835539.png

Mysql的布尔类型: mysql没有bool类型,但是有bool关键字(通过0和1来实现)

d555396f760a4cfb55ac7df35d3880de.png

5. 函数参数

函数的参数: 在mysql中,对函数参数的要求可以理解为强类型语言: 必须在定义函数参数(形参)指定其数据类型, 可以有多个形参

create function test(int_1 float ,int_2 int...)

要求在调用函数的时候,必须传入对应的实际参数: 个数与类型都必须完全一致

Mysql函数中函数的参数,不存在引用传递(都是值传递), 也没有默认值(每个形参都必须传入实参)

554c7f1419399aa580baafc9d5734b80.png

调用函数

454e240d14196844d1b35fde3d83571d.png

6. 函数返回值

函数内部(函数体) 的具体返回数据,必须与结构上指定的类型相同(returns)

41804c21e8155af0eeb39be77de00772.png

7. 函数体

函数体没有什么特殊说明: 就是外部执行功能某一些代码进行封装.

局部变量: 在局部作用域定义的变量(结构内部)

Declare 变量名 数据类型 [其他属性]; -- 一个结构内部若要声明局部变量: 必须是在所有代码的最前面.

60c32cc8b93e2e1af21b1f9f0bc6b47c.png

全局变量可以全局访问, 局部变量只能是函数内部访问.

897e07eecd6f908ef8344364abb5779d.png

作用域: 全局作用域是在任何地方可以直接访问, 局部只能在内部访问

ab39c497f6e56dd10d8a2bc5b39ba4e6.png

三、代码结构

代码结构:

顺序结构

分支结构

循环结构

1. 分支结构

if分支: 根据条件进行判断

if语法

if 条件判断 then --then表示如果满足条件--满足条件所有执行的事情

else

--可以再使用if进行条件判断: 有多少个if,一定有多少个end if;--不满足条件所有做的事情

end if;

函数: 比较三个数的大小

53f2e8d4a7dc7db8c256c5acf359f9d1.png

注意: 如果使用比较判断的话: 没有”==”,只有”=”

2. 循环结构

为了代码的重复执行.

while循环

while条件判断 do--循环体

--循环条件变更

end while;

需求: 求1到10之间的和

a1c47eb1853d723261b9bad91d35665c.png

循环控制: mysql中没有continue和break, 取而代之的是iterate和leave

循环名字:while条件 do

Iterate/leave 循环名字;end while;

求1到指定数之间的和,但是凡是5的倍数都不要

f45f8c7b18d53b21367aa00bdcc1d00f.png

存储过程

存储过程: procedure也叫做过程,是一种没有返回值的函数

函数是为了解决数据操作, 返回结果的话; 存储过程就是为了解决数据操作, 但是没有结果.

一、使用过程

定义语法

create procedure 过程名([参数列表])begin

--过程体: 与函数体完全一样(局部变量,全局变量,if分支,while循环)

end

存储过程没有返回值, 如果想显示数据,在内部使用select

1ebce48e30f8e7dc5bd15aa9d0002b7c.png

使用过程: 过程没有返回值: select不能使用

aae10a3de4a9ff54791c2d74639d0f03.png

过程调用: 有一个专门的关键字: call

3e60c31d4c5c77cbe27a0bac1972e32f.png

二、维护过程

查看过程: 查看所有过程:show procedure status;

83371dc9563fc831e7fca6af0ae9933a.png

查看过程的创建语句: show create procedure 过程名;

1c3f9545796828ef2980016717f55534.png

存储过程不能修改: 只能删除

drop procedure 过程名;

16d720d697eaa2692490a5bb266f0260.png

三、过程参数

存储过程的参数不单有数据类型,而且还有自己的类型

in: 传进去, 外部(实参)将数据传递给存储过程内部使用(内部可以使用): 但是对外部变量没有影响(值传递)

out: 传出去, 外部只需要对内部提供一个变量名, 内部会自动事先清空变量 = null, 然后内部对变量进行操作, 最后反应到外部的变量身上.(会内部事先清空变量引用传递)

inout: 传进去又可以传出去(典型引用传值)

语法: create procedure 过程名(过程参数类型 参数名 数据类型,....)

ff6b6d134b6795f1497522170c41e3be.png

out类型和inout类型都是类似引用传值: 意味着实参不能使用值常量,必须使用变量

f2ee977dd1c89e320400934cbd82115f.png

正常调用: 三个都传入变量

50de66457f4c476ee8c43e6ac932cf57.png

全局变量没有访问限制: 过程内部可以访问全局变量

c546b97eeccaa65b5b3aade51d550c7d.png

9d093a793bde73b2f47558cd329e53e1.png

存储过程和函数的区别:

一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。存储过程,功能强大,可以执行包括修改表等一系列数据库操作;用户定义函数不能用于执行一组修改全局数据库状态的操作。

对于存储过程来说可以返回参数,如记录集,而函数只能返回值或者表对象。函数只能返回一个变量;而存储过程可以返回多个。存储过程的参数可以有IN,OUT,INOUT三种类型,而函数只能有IN类~~存储过程声明时不需要返回类型,而函数声明时需要描述返回类型,且函数体中必须包含一个有效的RETURN语句。

存储过程,可以使用非确定函数,不允许在用户定义函数主体中内置非确定函数。

存储过程一般是作为一个独立的部分来执行( EXECUTE 语句执行),而函数可以作为查询语句的一个部分来调用(SELECT调用),由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。 SQL语句中不可用存储过程,而可以使用函数。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值