用于设置 NULL 值自定义值的 MySQL 存储过程中的条件 WHERE 子句


要为 NULL 值设置自定义值,请在存储过程中结合 IS NULL 属性使用 UPDATE 命令。让我们先创建一个表 −

mysql> create table DemoTable
(
   Id int,
   FirstName varchar(50)
);
Query OK, 0 rows affected (0.67 sec)

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

mysql> insert into DemoTable values(100,'Chris');
Query OK, 1 row affected (0.18 sec)
mysql> insert into DemoTable values(101,NULL);
Query OK, 1 row affected (0.20 sec)
mysql> insert into DemoTable values(102,'Mike');
Query OK, 1 row affected (0.38 sec)
mysql> insert into DemoTable values(103,NULL);
Query OK, 1 row affected (0.74 sec)

使用 select 语句显示表中的所有记录 −

mysql> select *from DemoTable;

这将生成以下输出 −

+------+-----------+
| Id   | FirstName |
+------+-----------+
| 100  | Chris     |
| 101  | NULL      |
| 102  | Mike      |
| 103  | NULL      |
+------+-----------+
4 rows in set (0.00 sec)

以下是创建存储过程的查询 −

mysql> DELIMITER //
mysql> create procedure where_clauseProc()
   BEGIN
   update DemoTable set FirstName='Robert' where FirstName IS NULL;
   END //
Query OK, 0 rows affected (4.11 sec)
mysql> DELIMITER ;

使用 CALL 命令调用存储过程 −

mysql> call where_clauseProc();
Query OK, 2 rows affected (0.10 sec)

使用 select 语句显示表中的所有记录 −

mysql> select *from DemoTable;

这将生成以下输出 −

+------+-----------+
| Id   | FirstName |
+------+-----------+
| 100  | Chris     |
| 101  | Robert    |
| 102  | Mike      |
| 103  | Robert    |  
+------+-----------+
4 rows in set (0.00 sec)

更新于: 03-10-2019

197 次浏览

开启你的职业生涯

完成课程获取认证

开始学习
广告