如何利用 MySQL 中查询的结果设置用户变量?


要利用 MySQL 中查询的结果设置用户变量,你需要将变量移动到分配中。

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

mysql> create table UserVariable
   -> (
   -> Id int,
   -> Name varchar(100)
   -> );
Query OK, 0 rows affected (0.53 sec)

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

mysql> insert into UserVariable values(101,'John');
Query OK, 1 row affected (0.17 sec)

mysql> insert into UserVariable values(200,'Tom');
Query OK, 1 row affected (0.18 sec)

mysql> insert into UserVariable values(500,'Carol');
Query OK, 1 row affected (0.13 sec)

使用选择命令显示表中的所有记录。查询如下 −

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);
Query OK, 0 rows affected (0.00 sec)

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

mysql> set @Name=(select Name from UserVariable where Id=@Maxid);
Query OK, 0 rows affected (0.00 sec)

现在你可以检查变量 Name 中存在什么值。查询如下 −

mysql> select @Name;

以下是显示具有最高 Id 的名称的输出 −

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

更新于:30-Jul-2019

943 次浏览

开启你的职业生涯

通过完成课程来获得认证

开始
广告