用户定义的变量也称为特定于会话的变量。它是一种类型松散的变量,可以在会话中的某个位置进行初始化,并包含用户定义的变量的值,直到会话结束。
用户定义的变量以符号@开头。例如:@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用户定义的变量不进行每个过程调用。