iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL 中的用户定义变量与局部变量?
  • 256
分享到

MySQL 中的用户定义变量与局部变量?

2023-10-22 10:10:34 256人浏览 独家记忆
摘要

用户定义的变量也称为会话特定变量。它是一种松散类型变量,可以在会话中的某个位置进行初始化,并包含用户定义变量的值,直到会话结束。用户定义变量以符号 @ 为前缀。例如:@anyVariableName;有两种方法可以初始化用户定义的变量。您可

用户定义的变量也称为会话特定变量。它是一种松散类型变量,可以在会话中的某个位置进行初始化,并包含用户定义变量的值,直到会话结束。

用户定义变量以符号 @ 为前缀。例如:

@anyVariableName;

有两种方法可以初始化用户定义的变量。您可以使用 SET 命令或使用 SELECT 查询。第一种方法如下:

SET @anyVariableName=anyValue;

第二种方法如下:

SELECT @anyVariableName :=anyValue;

如果您在 SELECT 查询中不使用冒号 (:),则会将其计算为表达式。结果要么为真,要么为假:

Mysql> select @m=10;

以下是输出:

+-------+
| @m=10 |
+-------+
|     1 |
+-------+
1 row in set (0.00 sec)

局部变量可以在存储过程、函数等中使用,与DECLARE关键字一起使用。不需要像用户定义变量那样的@前缀。

局部变量的语法如下。

DECLARE yourVariableName dataType;

注意:局部变量和用户定义变量之间的主要区别在于,每次调用存储过程时,局部变量都会用 NULL 值重新初始化,而会话特定变量或用户定义变量则不会。未使用 NULL 重新初始化。一个用户设置的用户定义变量不能被其他用户看到。给定用户的任何会话变量都会在用户退出时自动销毁。

这里是会话特定变量和局部变量的演示与存储过程。创建带有局部变量和用户定义变量的存储过程的查询如下:

mysql> DELIMITER //
mysql> CREATE PROCEDURE sp_LocalAndUserDefinedVariableDemo()
   -> BEGIN
   -> DECLARE localVariable int default 10;
   -> SET localVariable=localVariable+10;  
   -> SET @userVariable=@userVariable+10;
   -> SELECT localVariable;
   -> SELECT @userVariable;
   -> END;
   -> //
Query OK, 0 rows affected (0.39 sec)
mysql> DELIMITER ;

现在设置用户定义变量的值。查询如下:

mysql> SET @userVariable=10;
Query OK, 0 rows affected (0.00 sec)

现在调用存储过程。第一次调用时,用户定义变量为 10+10=20,局部变量为 10+10=20。

使用 call 命令调用存储过程:

mysql> CALL sp_LocalAndUserDefinedVariableDemo();

以下是输出:

+---------------+
| localVariable |
+---------------+
|            20 |
+---------------+
1 row in set (0.32 sec)
+---------------+
| @userVariable |
+---------------+
|            20 |
+---------------+
1 row in set (0.34 sec)
Query OK, 0 rows affected (0.36 sec)

在第二次调用中,用户定义的变量将保存值 20 并添加 10,如 20+10=30,而局部变量再次用 10 重新初始化并添加 10,如 10+10=20。

调用存储过程并检查示例输出:

mysql> CALL sp_LocalAndUserDefinedVariableDemo();

以下是输出:

+---------------+
| localVariable |
+---------------+
|            20 |
+---------------+
1 row in set (0.00 sec)
+---------------+
| @userVariable |
+---------------+
|            30 |
+---------------+
1 row in set (0.01 sec)
Query OK, 0 rows affected (0.02 sec)

在第三次调用中,用户定义的变量将保存值 30 并添加 10,如 30+10=40,而局部变量再次使用 10 重新初始化并添加 10,如 10+10=20。

现在你可以说,在每个过程调用中,局部变量都用某个值重新初始化,该值可能是 NULL 或其他值,就像在我的例子中,我提供了默认值 10。这意味着它将局部变量设置为值 10每个过程调用,而用户定义的变量则不然。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL 中的用户定义变量与局部变量?

本文链接: https://www.lsjlt.com/news/436833.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL 中的用户定义变量与局部变量?
    用户定义的变量也称为会话特定变量。它是一种松散类型变量,可以在会话中的某个位置进行初始化,并包含用户定义变量的值,直到会话结束。用户定义变量以符号 @ 为前缀。例如:@anyVariableName;有两种方法可以初始化用户定义的变量。您可...
    99+
    2023-10-22
  • mysql怎么定义局部变量
    在MySQL中,可以使用SET语句来定义局部变量。局部变量可以在存储过程、函数、触发器等MySQL代码块中使用。下面是一个示例: D...
    99+
    2024-04-09
    MySQL
  • MySQL 中的系统变量与局部变量?
    局部变量的作用域仅限于一组语句或语句块。每当一组语句或语句块完成时,局部变量就会超出范围。例如局部变量可以在存储过程、函数等中使用.与DECLARE关键字一起使用。局部变量的语法如下。DECLARE yourVariableName dat...
    99+
    2023-10-22
  • Java局部变量怎么定义
    在Java中,局部变量是在方法、构造函数或语句块中声明的变量。局部变量只在声明它的方法、构造函数或语句块内可见。要定义一个Java局...
    99+
    2023-09-05
    Java
  • Shell全局变量、局部变量与特殊变量的具体使用
    目录1、全局变量(环境变量):2、局部变量(本地变量):3、关于局部变量的其它一些问题4、Shell的特殊变量:变量类型:全局变量(环境变量)和局部变量(本地变量)环境变量可以在定义它们的shell及其派生出来的任意子进...
    99+
    2023-05-06
    Shell全局变量 Shell局部变量 Shell特殊变量
  • 在 MySQL 中使用用户定义的变量
    让我们了解什么是用户变量以及如何在 MySQL 中使用它们。我们还将看到规则 -用户变量被写为@var_name。这里,“var_name”指的是变量名,由字母数字字符、.、_和$组成。用户变量名可以包含其他字符(如果被引号引起来)作为字符...
    99+
    2023-10-22
  • Golang函数中的变量作用域:局部变量和全局变量
    Golang函数中的局部变量和全局变量,需要具体代码示例 在Golang中,变量的作用域是非常重要的概念。在函数中,我们常常会遇到局部变量和全局变量的情况。这两者在作用域和使用方式上有一些区别,下面我将详细介...
    99+
    2024-01-18
    函数 变量 Golang
  • javascript中全局变量与局部变量有哪些区别
    这篇文章主要讲解了“javascript中全局变量与局部变量有哪些区别”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript中全局变量与局部变量...
    99+
    2024-04-02
  • java中局部变量与全局变量的区别有哪些
    本篇文章为大家展示了java中局部变量与全局变量的区别有哪些,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、局部变量:局部变量的定义:定义在方法中的变量都是局部变量(main方法也是方法,所以定义...
    99+
    2023-05-31
    java 局部变量 全局变量
  • JavaScript局部变量与全局变量的作用域是什么
    本文小编为大家详细介绍“JavaScript局部变量与全局变量的作用域是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript局部变量与全局变量的作用域是什么”文章能帮助大家解决疑惑,下面...
    99+
    2024-04-02
  • C语言中全局变量与局部变量的示例分析
    小编给大家分享一下C语言中全局变量与局部变量的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一:局部变量与全局变量1.1:局部变量局部变量:在函数内部定义...
    99+
    2023-06-25
  • JavaScript把局部变量变成全局变量的方法
    首先我们要知道函数的自调用 函数的自调用——自调用函数 一次性的函数——声明的同时,直接调用了 例如: (function () { console.log("函数"); ...
    99+
    2024-04-02
  • Python之全局与局部变量
    ''' 命名空间 : 每次在python解释器启动之后,就会在内存开辟一块内存空间,每当遇到一个变量时,就会在命名空间中,记录下变量名和值之间的关系,也即记录变量对应的值在内存空间中的            地址;当一个函数时,会在命名空间...
    99+
    2023-01-31
    全局 变量 局部
  • Linux的全局变量、局部变量、环境变量实例分析
    本文小编为大家详细介绍“Linux的全局变量、局部变量、环境变量实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“Linux的全局变量、局部变量、环境变量实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧...
    99+
    2023-06-28
  • jquery中如何定义全局变量
    在jquery中定义全局变量的方法:1.新建html项目,引入jquery;2.使用var关键字定义全局变量;具体步骤如下:首先,新建一个html项目,并在项目中引入jquery;<script type="text/jav...
    99+
    2024-04-02
  • c#中怎么定义全局变量
    非常抱歉,由于您没有提供文章标题,我无法为您生成一篇高质量的文章。请您提供文章标题,我将尽快为您生成一篇优质的文章。...
    99+
    2024-05-14
  • Python中如何定义全局变量
    今天就跟大家聊聊有关Python中如何定义全局变量,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 声明法该方法是直接在当前模块中进行全局变量定义声明,使用global的声明方式,再进...
    99+
    2023-06-04
  • nodejs中怎么定义全局变量
    本篇内容主要讲解“nodejs中怎么定义全局变量”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“nodejs中怎么定义全局变量”吧! ...
    99+
    2024-04-02
  • python全局变量-局部变量用法和区别
    对于很多初学的同学,对全局和局部变量容易混淆,看看下面给大家的讲解相信都应该明白 两者的区别了。 定义:全局变量:在模块内、在所有函数的外面、在class外面局部变量:在函数内、在class的方法内 下面来看看例子函数内部调用全局变量 a=...
    99+
    2023-01-31
    变量 局部 区别
  • Vue 中怎么实现全局变量和局部变量
    本篇文章为大家展示了Vue 中怎么实现全局变量和局部变量,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。局组件和局部组件1.先定义组件   Vue...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作