MySQL 9.0 参考手册  /  ...  /  使用用户定义变量

5.6.5 使用用户定义变量

您可以使用 MySQL 用户变量来记住结果,而无需将它们存储在客户端的临时变量中。(请参阅 第 11.4 节,“用户定义变量”。)

例如,要查找价格最高和最低的文章,您可以这样做

mysql> SELECT @min_price:=MIN(price),@max_price:=MAX(price) FROM shop;
mysql> SELECT * FROM shop WHERE price=@min_price OR price=@max_price;
+---------+--------+-------+
| article | dealer | price |
+---------+--------+-------+
|    0003 | D      |  1.25 |
|    0004 | D      | 19.95 |
+---------+--------+-------+
注意

也可以将数据库对象(如表或列)的名称存储在用户变量中,然后在 SQL 语句中使用该变量;但是,这需要使用预处理语句。有关更多信息,请参阅 第 15.5 节,“预处理语句”