变量
在本教程中,您将学习如何在SQL语句中使用MySQL用户定义的变量。
MySQL用户定义变量简介
有时候,您希望将值从SQL语句传递给另一个SQL语句。为此,您可将该值存储在第一个语句中的MySQL用户定义的变量中,并在随后的语句中引用它。
要创建用户定义的变量,请使用格式@variable_name
,其中variable_name
由字母数字字符组成。 用户自定义变量的最大长度为64个字符(MySQL 5.7.5之前的版本)
用户定义的变量不区分大小写。 这意味着@id
和@ID
是一样的。
可以将用户定义的变量分配给某些数据类型,例如整数,浮点,小数,字符串或NULL。
由一个客户端定义的用户定义的变量不被其他客户端看到。 换句话说,用户定义的变量是特定于会话的。
注意,用户定义的变量是MySQL特定于SQL标准的扩展。 它们在其他数据库系统中可能不可用。
MySQL变量赋值
有两种方法可以将值分配给用户定义的变量。
第一种方法是使用SET
语句如下:
您可以使用:=
或=
作为SET
语句中的赋值运算符。 例如,该语句将数字100
分配给变量@counter
。
为变量分配值的第二种方法是使用SELECT语句。 在这种情况下,您必须使用:=
赋值运算符,因为在SELECT
语句中,MySQL将=
运算符视为相等运算符。
在赋值之后,可以使用后续语句中允许表达式的变量,例如,在WHERE子句,INSERT或UPDATE语句中。
MySQL变量示例
以下语句在products
表中查询获得最昂贵的产品,并将价格分配给用户定义的变量@msrp
:
执行上面查询语句,得到以下结果 -
以下语句使用@msrp
变量来查询最昂贵产品的信息。
有时候,您想要在表中插入一行,获取最后一个插入ID,并使用将此ID作一项数据插入另一个表。 在这种情况下,您可以使用用户定义的变量来存储AUTO_INCREMENT列生成的最新ID
,如下所示。
用户定义的变量只能保存一个值。 如果SELECT
语句返回多个值,则变量将获取结果中最后一行的值。
执行上面语句,得到以下结果 -
接下来,查询上面变量(@buyprice
)的值,结果如下所示 -
在本教程中,我们向您展示了如何使用SQL语句中的MySQL变量在会话内的语句之间传递数据。
Last updated