目录
mysql存储过程有什么变量类型
一、局部变量" >一、局部变量
二、用户变量" >二、用户变量
三、MySQL变量之用户变量与系统变量" >三、MySQL变量之用户变量与系统变量
首页 数据库 mysql教程 mysql存储过程有什么变量类型

mysql存储过程有什么变量类型

May 16, 2022 am 10:30 AM
mysql

mysql存储过程的变量类型:1、局部变量,定义语法为“DECLARE 变量名 数据类型”;2、用户变量,定义语法为“set @变量名:=...”;3、系统变量,可分为全局变量“@@global”和会话变量“@@session”。

mysql存储过程有什么变量类型

本教程操作环境:windows10系统、mysql8.0.22版本、Dell G3电脑。

mysql存储过程有什么变量类型

MySQL存储过程常见的变量:局部变量、用户变量、系统变量

一、局部变量

在过程体中,可以声明局部变量,用来临时保存一些值。

1、定义局部变量语法:

DECLARE  var_name[, var_name] ...  type [DEFAULT value];
登录后复制

其中,type为MySQL的数据类型,如:int、float、date、varchar(length)

注意:

①DECLARE用来声明局部变量,且DECLARE仅被用在BEGIN ... END复合语句里,并且必须在复合语句的开头,在任何其它语句之前;可以被用在嵌套的块中,除了那些用相同名字声明变量的块。

②如果要给变量提供一个默认值,使用DEFAULT子句(值可以是常数,也可以指定为一个表达式);如果没有DEFAULT子句,初始值为NULL。

2、基本格式:

CREATE PROCEDURE sp_name ([proc_parameter[,...]])
BEGIN
DECLARE var_name1 type [DEFAULT value];
DECLARE var_name2 type [DEFAULT value];
DECLARE……;
[characteristic ...];
登录后复制

例1:创建过程,为局部变量指定默认值,并调用该过程

mysql>delimiter $$
mysql> create procedure test1(out num1 int)->begin-> declare num2 int default 100;-> set num1=num2;->end->$$
mysql>delimiter ;
mysql>call test1(@num);
mysql> select@num;+------+
| @num |
+------+
| 100 |
+------+
登录后复制

解析:

创建test1存储过程:输出的是num1变量的值,声明局部变量num2是int类型、默认值是100,用set将num2的值(未处理,则默认值)赋给num1;

调用test1:用用户变量num去接收存储过程的输出值num1……

默认值除了字面量,还可以是复杂的表达式,包括标量子查询

例2:创建过程,使用所有球员的数量来初始化一个变量

mysql>delimiter $$
mysql> create procedure test2(out num1 int)->begin-> declare num2 int default(select count(*) fromPLAYERS);-> set num1=num2;->end$$mysql>delimiter ;
mysql>call test2(@num);mysql> select@num;+------+
| @num |
+------+
| 14 |
+------+
登录后复制

注意:MySQL不支持数组作为局部变量。

3、局部变量的作用域:

也就是变量能正常使用而不出错的程序块的范围。

在嵌套块的情况下,

在外部块中声明的变量可以在内部块中直接使用;

在内部块中声明的变量只能在内部块中使用。

4d642006509b50e8077cc4f4d4170260.png

解析:变量v2只能用在内部块b2中,块b3中的set语句和最后一条set语句都是错误的。

二、用户变量

>用户变量与数据库连接有关:在当前连接中声明的变量,在连接断开的时候,就会消失;在此连接中声明的变量无法在另一连接中使用。

>一个@符号表示的就是用户变量。

1、用户变量的定义(set、select):

1)set语句为用户变量赋值:

可以使用“=”或“:=”作为分配符;

分配给每个变量的expr可以为整数、实数、字符串或者NULL值;

mysql> set @zjc:=999;
mysql> select@zjc;+------+
| @zjc |
+------+
| 999 |
+------+
登录后复制

2)select语句为用户变量赋值:

分配符必须为“:=”而不能用“=”,因为在非SET语句中=被视为一个比较操作符;

mysql> select @abc:=123;+-----------+
| @abc:=123 |
+-----------+
| 123 |
+-----------+mysql> select@abc;+------+
| @abc |
+------+
| 123 |
+------+
登录后复制

注意:

①用户变量随处可以定义,随处可以使用;不定义可以直接使用(值默认为null)。

②用户变量的变量名的形式:@var_name,要有@符号。

③滥用用户变量会导致程序难以理解及管理。

拓展之变量赋值:set语法

MySQL里面的变量是不严格限制数据类型的,变量的数据类型根据赋给变量的值而随时变化。

SET variable_assignment [, variable_assignment] ...
variable_assignment:
user_var_name=expr|[GLOBAL | SESSION] system_var_name =expr|[@@global. | @@session. | @@] system_var_name = expr
登录后复制

##用来给用户变量、系统变量赋值,也可以给过程中的局部变量赋值。

注意:

set系统变量时,不带作用域修饰,默认是指会话作用域;

(特别注意,有些系统变量不带作用域修饰,无法设置,因此最好都带上作用域设置系统变量)。

2、用户变量的作用域

只要是在当前连接定义的用户变量,在当前连接里用都是OK的,除此之外都不行。

3、与局部变量区别:

局部变量只有变量名字,没有@符号;用户变量名前有@符号。

都是先定义,再使用;未定义的变量,select值为空。

局部变量只在存储过程内部使用,在过程体外是没有意义的,当begin-end块处理完后,局部变量就消失;而用户变量可以用在存储过程的内部和外部。

Tips:在存储过程内部,使用局部变量,不要使用用户变量。

三、MySQL变量之用户变量与系统变量

1、用户变量如上所述@var_name(一个@符号)

①用户变量和数据库连接有关,连接后声明变量,连接断开后,自动消失;

②select一个没有赋值的用户变量,返回NULL,也就是没有值;

Mysql的变量类似于动态语言,变量的值随所要赋的值的类型而改变。

2、系统变量:根据系统变量的作用域分为:全局变量与会话变量(两个@符号)

①全局变量(@@global.)

在MySQL启动的时候由服务器自动将全局变量初始化为默认值;

全局变量的默认值可以通过更改MySQL配置文件(my.ini、my.cnf)来更改。

②会话变量(@@session.)

在每次建立一个新的连接的时候,由MySQL来初始化;

MYSQL会将当前所有全局变量的值复制一份来做为会话变量(也就是说,如果在建立会话以后,没有手动更改过会话变量与全局变量的值,那所有这些变量的值都是一样的)。

#全局变量与会话变量的区别:对全局变量的修改会影响到整个服务器,但是对会话变量的修改,只会影响到当前的会话。

推荐学习:mysql视频教程

以上是mysql存储过程有什么变量类型的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

MySQL:初学者的数据管理易用性 MySQL:初学者的数据管理易用性 Apr 09, 2025 am 12:07 AM

MySQL适合初学者使用,因为它安装简单、功能强大且易于管理数据。1.安装和配置简单,适用于多种操作系统。2.支持基本操作如创建数据库和表、插入、查询、更新和删除数据。3.提供高级功能如JOIN操作和子查询。4.可以通过索引、查询优化和分表分区来提升性能。5.支持备份、恢复和安全措施,确保数据的安全和一致性。

phpmyadmin怎么打开 phpmyadmin怎么打开 Apr 10, 2025 pm 10:51 PM

可以通过以下步骤打开 phpMyAdmin:1. 登录网站控制面板;2. 找到并点击 phpMyAdmin 图标;3. 输入 MySQL 凭据;4. 点击 "登录"。

mysql:简单的概念,用于轻松学习 mysql:简单的概念,用于轻松学习 Apr 10, 2025 am 09:29 AM

MySQL是一个开源的关系型数据库管理系统。1)创建数据库和表:使用CREATEDATABASE和CREATETABLE命令。2)基本操作:INSERT、UPDATE、DELETE和SELECT。3)高级操作:JOIN、子查询和事务处理。4)调试技巧:检查语法、数据类型和权限。5)优化建议:使用索引、避免SELECT*和使用事务。

MySQL和SQL:开发人员的基本技能 MySQL和SQL:开发人员的基本技能 Apr 10, 2025 am 09:30 AM

MySQL和SQL是开发者必备技能。1.MySQL是开源的关系型数据库管理系统,SQL是用于管理和操作数据库的标准语言。2.MySQL通过高效的数据存储和检索功能支持多种存储引擎,SQL通过简单语句完成复杂数据操作。3.使用示例包括基本查询和高级查询,如按条件过滤和排序。4.常见错误包括语法错误和性能问题,可通过检查SQL语句和使用EXPLAIN命令优化。5.性能优化技巧包括使用索引、避免全表扫描、优化JOIN操作和提升代码可读性。

navicat premium怎么创建 navicat premium怎么创建 Apr 09, 2025 am 07:09 AM

使用 Navicat Premium 创建数据库:连接到数据库服务器并输入连接参数。右键单击服务器并选择“创建数据库”。输入新数据库的名称和指定字符集和排序规则。连接到新数据库并在“对象浏览器”中创建表。右键单击表并选择“插入数据”来插入数据。

navicat怎么新建连接mysql navicat怎么新建连接mysql Apr 09, 2025 am 07:21 AM

可在 Navicat 中通过以下步骤新建 MySQL 连接:打开应用程序并选择“新建连接”(Ctrl N)。选择“MySQL”作为连接类型。输入主机名/IP 地址、端口、用户名和密码。(可选)配置高级选项。保存连接并输入连接名称。

navicat如何执行sql navicat如何执行sql Apr 08, 2025 pm 11:42 PM

在 Navicat 中执行 SQL 的步骤:连接到数据库。创建 SQL 编辑器窗口。编写 SQL 查询或脚本。单击“运行”按钮执行查询或脚本。查看结果(如果执行查询的话)。

Navicat 连接数据库错误代码及解决办法 Navicat 连接数据库错误代码及解决办法 Apr 08, 2025 pm 11:06 PM

Navicat 连接数据库时常见的错误及解决方案:用户名或密码错误(Error 1045)防火墙阻止连接(Error 2003)连接超时(Error 10060)无法使用套接字连接(Error 1042)SSL 连接错误(Error 10055)连接尝试过多导致主机被阻止(Error 1129)数据库不存在(Error 1049)没有权限连接到数据库(Error 1000)

See all articles