MySQL变量类型比较:@variable
与variable
MySQL 提供两种类型的变量:用户自定义变量和会话级用户自定义变量。后者以@
符号开头(@variable
),而前者没有(variable
)。
用户自定义变量
这类变量类型宽松,并在整个会话期间保持其值。它们在任何存储过程之外使用SET
语句创建。例如:
<code class="language-sql">SET @var = 1;</code>
会话级用户自定义变量
与用户自定义变量不同,这些变量仅在当前会话中可见。它们在存储过程中声明并作为参数传递。例如:
<code class="language-sql">CREATE PROCEDURE prc_test(var INT) BEGIN DECLARE var2 INT; SET var2 = 1; END;</code>
主要区别
这两种变量类型的主要区别在于它们的范围和初始化方式。过程变量每次调用过程时都会重新初始化为NULL
,而会话级变量在跨过程调用时会保留其值。以下代码片段演示了这一点:
<code class="language-sql">CREATE PROCEDURE prc_test() BEGIN DECLARE var2 INT DEFAULT 1; SET var2 = var2 + 1; SET @var2 = @var2 + 1; END; SET @var2 = 1;</code>
示例输出:
var2 | @var2 |
---|---|
2 | 2 |
2 | 3 |
2 | 4 |
正如您所看到的,var2
每次都会重新初始化,而@var2
在跨调用时累积值的变化。
结论
理解@variable
和variable
之间的区别对于有效的MySQL开发至关重要。它允许您根据变量的范围和初始化行为适当地管理变量,从而确保代码效率和准确性。
以上是MySQL 中的 @variable 与变量:有什么区别?的详细内容。更多信息请关注PHP中文网其他相关文章!