变量&存储过程&函数

🫐变量

1、系统变量

  • 系统变量:变量由系统提供,不是用户定义的,属于服务器层面的,根据作用域的不同分为:全局变量、会话变量
  • 查看所有的系统变量
show global variables;

show [session] variables;

  • 查看满足条件的部分系统变量
show [session]|global variables like '%char%';
  • 查看指定的某个系统变量的值
select @@global | [session]. 系统变量名
#例子
select @@transaction_isolation;
  • 为某个系统变量赋值
# 方式一:
set global | [session] 变量名= 值;
#方式二:
set @@global | [session] .变量名=值;
  • 全局变量的作用域:服务器每次启动将会为所有的全局变量赋初始值,针对与所有的会话(连接)都有效。
  • 会话变量的作用域:仅仅针对当前的会话(连接)有效

2、自定义变量

  • 自定义变量:用户变量、局部变量
  • 步骤:声明、赋值、使用(查看、比较、运算等)
  • 用户变量:针对当前会话(连接)有效,同于会话变量的作用域

1>用户变量在声明时必须初始化

# 声明并初始化:三种方式
set @用户变量名= 值;
set @用户变量名:= 值;
select @用户变量名:= 值;

2>赋值(更新用户变量的值)

# 方式一:通过set或者select
set @用户变量名= 值;
set @用户变量名:= 值;
select @用户变量名:= 值;
#方式二: 通过select into
select 字段 into 用户变量名 
from 表;
#上面的字段只能是一个值

3>使用

select @用户变量名;
  • 用户变量可以使用在任何地方,也就是begin end里面,或者外面
  • 局部变量:仅仅在定义它的begin end中有效,且必须放在begin end的第一句话

1> 声明

Declare 变量名 类型;
declare 变量名 类型 default 类型

2>赋值
赋值(更新局部变量的值)

# 方式一:通过set或者select
set 局部变量名= 值;
set 局部变量名:= 值;
select @局部变量名:= 值;
#方式二: 通过select into
select 字段 into 局部变量名 
from 表;
#上面的字段只能是一个值

3>使用

select 局部变量;

🍑存储过程

  • 存储过程是一组预先编译好的sql语句的集合
  • 特点:提高代码的重用性;简化操作;减少了编译次数并且减少了和数据库服务器的连接次数,提高了效率
  • 创建语法
create procedure 存储过程名(参数列表)
begin
    存储过程体(一组合法的sql语句)
end

参数列表包含三个部分:参数模式-参数名-参数类型

  • 参数模式:
    in:该参数可以作为输入,也就是该参数需要调用方传入值
    out:该参数可以作为输出,也就是该参数可以作为返回值
    inout:该参数既可以作为输入也可以作为输出,也就是该参数既需要传入值,也可以返回值
  • 如果存储过程的方法体仅仅只有一句话,则begin end可以省略
    存储过程体中的每条sql语句的结尾要求必须加分号
    存储过程的结尾标识符可以使用delimiter重新设置
delimiter 结束标记 
  • 调用语法
call 存储过程名(实参列表);
  • 例子
delimiter $
create procedure 存储过程名(参数列表)
begin
      一组sql语句;
end $

#调用的时候
call 存储过程名(参数列表) $
#这里应该使用为存储过程定义的结束符
  • 删除存储过程
drop procedure 存储过程名
  • 查看存储过程的结构
show create procedure 存储结构名;

🍊函数

  • 与存储过程的不同:存储过程可以有0个或多个返回值,适合做批量插入、批量更新;函数有且仅有一个返回值,适合进行数据处理后返回一个结果
  • 语法:
create function 函数名(参数列表) returns 返回值类型
begin
  函数体
end

参数列表包含两个部分:参数名 参数类型
函数体内一定有return语句,如果没有会报错
函数体中只有一句话时,可以省略begin end
同样要使用delimiter语句设置结束标记

  • 调用
select 函数名(参数列表)
  • 例子:
# 返回公司的员工个数
delimiter $
create function countNum() returns int
begin
  declare res int default 0;
  select count(*) into res 
  from employees;
  return res;
end $

select countNum()$
  • 查看函数的结构
show create 函数名;
  • 删除函数
drop function 函数名;
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容