MySQL
 Computer >> コンピューター >  >> プログラミング >> MySQL

NULL値のカスタム値を設定するためのMySQLストアドプロシージャの条件付きWHERE句


NULL値のカスタム値を設定するには、ストアドプロシージャでISNULLプロパティとともに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)

  1. MySQLのカスタム列に複数の値を設定しますか?

    このために、UNIONALLを使用できます。まずテーブルを作成しましょう- mysql> create table DemoTable1987    (    UserValue int    ); Query OK, 0 rows affected (2.90 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql> insert into DemoTable1987 values(4); Query OK, 1 row affected (0.22 sec) mysql> in

  2. MySQLで列挙値のカスタムメッセージを設定する

    if elseを使用して、列挙型のカスタムメッセージを設定します。まずテーブルを作成しましょう- mysql> create table DemoTable1992 (    ClientId int NOT NULL AUTO_INCREMENT PRIMARY KEY,    ClientName varchar(20),    isActive ENUM('Y','N') ); Query OK, 0 rows affected (0.89 sec) 挿入コマンド-を使用して、テーブルにい