在MySQL中根据查询结果设置用户变量?

要根据MySQL中的查询结果设置用户变量,您需要将该变量移至赋值中。

为了理解上述概念,让我们首先创建一个表。创建表的查询如下-

mysql> create table UserVariable
   -> (
   -> Id int,
   -> Name varchar(100)
   -> );

使用insert命令在表中插入一些记录。查询如下-

mysql> insert into UserVariable values(101,'John');

mysql> insert into UserVariable values(200,'Tom');

mysql> insert into UserVariable values(500,'Carol');

使用select命令显示表中的所有记录。查询如下-

mysql> select *from UserVariable;

输出结果

+------+-------+
| Id   | Name  |
+------+-------+
|  101 | John  |
|  200 | Tom   |
|  500 | Carol |
+------+-------+
3 rows in set (0.00 sec)

使用用户变量编写查询,该查询显示具有最大id的记录。首先,我将创建一个变量并通过从上表中选择最大ID来初始化此变量。查询如下-

mysql> set @Maxid=(select MAX(Id) from UserVariable);

之后,创建另一个仅具有特定最大ID名称的变量。查询如下-

mysql> set @Name=(select Name from UserVariable where Id=@Maxid);

现在,您可以检查变量名称中存在什么值。查询如下-

mysql> select @Name;

以下是显示具有最高ID的名称的输出-

+-------+
| @Name |
+-------+
| Carol |
+-------+
1 row in set (0.00 sec)