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

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

用户定义的变量以符号@开头。例如:

@anyVariableName;

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

SET @anyVariableName=anyValue;

第二种方法如下:

SELECT @anyVariableName :=anyValue;

如果未在SELECT查询中使用冒号(:),则它将其作为表达式求值。结果将为true或false:

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;

   -> //

mysql> DELIMITER ;

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

mysql> SET @userVariable=10;

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

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

mysql> CALL sp_LocalAndUserDefinedVariableDemo();

以下是输出:

+---------------+

| localVariable |

+---------------+

|            20 |

+---------------+

1 row in set (0.32 sec)

+---------------+

| @userVariable |

+---------------+

|            20 |

+---------------+

1 row in set (0.34 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)

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

现在您可以说,在每个过程调用中,局部变量都使用某个值(可能为NULL或其他值)重新初始化,例如在我的情况下,我提供了默认值10。这意味着它将局部变量设置为10用户定义的变量不进行每个过程调用。

以上是 用户定义变量与MySQL中的局部变量? 的全部内容, 来源链接: utcz.com/z/326544.html

回到顶部