用包含 IF…THEN…END IF 语句的 MySQL 存储过程显示记录
我们首先创建一个表 -
mysql> create table DemoTable643 (ClientId int); Query OK, 0 rows affected (0.86 sec)
使用 insert 命令在表中插入一些记录 -
mysql> insert into DemoTable643 values(1000); Query OK, 1 row affected (0.19 sec)
使用 select 语句显示表中的所有记录 -
mysql> select *from DemoTable643;
这将生成以下输出 -
+----------+ | ClientId | +----------+ | 1000 | +----------+ 1 row in set (0.00 sec)
以下是带 IF THEN END IF 的 MySQL 存储过程的查询 -
mysql> DELIMITER // mysql> CREATE PROCEDURE IF_DEMO(argument int) BEGIN DECLARE firstArgument int; DECLARE secondArgument int; set firstArgument=0; set secondArgument=1; IF firstArgument=argument THEN insert into DemoTable643 values(2000); END IF; IF secondArgument=argument THEN select *from DemoTable643; END IF; END // Query OK, 0 rows affected (0.12 sec) mysql> DELIMITER ;
使用 call 命令调用存储过程 -
mysql> call IF_DEMO(0); Query OK, 1 row affected (0.17 sec)
以下是显示存储过程中的所有记录的查询 -
mysql> call IF_DEMO(1);
这将生成以下输出 -
+----------+ | ClientId | +----------+ | 1000 | | 2000 | +----------+ 2 rows in set (0.00 sec) Query OK, 0 rows affected (0.03 sec)
广告