如何使用单个MySQL select语句在存储过程中设置两个变量?

为此,让我们首先在MySQL中创建一个新表

mysql> create table useProcedure
   - > (
   - > Id int NOT NULL AUTO_INCREMENT PRIMARY KEY,
   - > FirstName varchar(20),
   - > LastName varchar(20)
   - > );

使用insert命令在表中插入一些记录。

查询如下

mysql> insert into useProcedure(FirstName,LastName) values('Adam','Smith');

以下是使用单个select语句在存储过程中设置两个变量的存储过程。创建存储过程的查询如下

mysql> DELIMITER //
mysql> create procedure Sp_Demo()
   - > BEGIN
   - > declare one varchar(20);
   - > declare two varchar(20);
   - > select FirstName, LastName INTO one, two from useProcedure where id = 1;
   - > select one, two;
   - > END;
   - > //
mysql> DELIMITER ;

借助CALL命令调用存储过程。

查询如下

mysql> call Sp_Demo();

以下是输出

+------+-------+
| one  | two   |
+------+-------+
| Adam | Smith |
+------+-------+
1 row in set (0.00 sec)