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

NULLの代わりにカスタム値を配置するMySQLCASEステートメント


まずテーブルを作成しましょう-

mysql> create table DemoTable
(
   FirstName varchar(20)
);
Query OK, 0 rows affected (1.15 sec)

挿入コマンド-

を使用して、テーブルにいくつかのレコードを挿入します
mysql> insert into DemoTable values('John');
Query OK, 1 row affected (0.11 sec)
mysql> insert into DemoTable values(NULL);
Query OK, 1 row affected (0.13 sec)
mysql> insert into DemoTable values('Adam');
Query OK, 1 row affected (0.14 sec)
mysql> insert into DemoTable values(NULL);
Query OK, 1 row affected (0.09 sec)

selectステートメントを使用してテーブルのすべてのレコードを表示する-

mysql> select *from DemoTable;

これにより、次の出力が生成されます-

+-----------+
| FirstName |
+-----------+
| John      |
| NULL      |
| Adam      |
| NULL      |
+-----------+
4 rows in set (0.00 sec)

ここでCASEステートメントを使用しましょう-

mysql> select case when FirstName is NULL then 'UNKNOWN NAME' else FirstName end AS FirstName from DemoTable;

これにより、次の出力が生成されます-

+--------------+
| FirstName    |
+--------------+
| John         |
| UNKNOWN NAME |
| Adam         |
| UNKNOWN NAME |
+--------------+
4 rows in set (0.00 sec)

IFNULL()-

を使用して同じ結果を取得することもできます
mysql> select IFNULL(FirstName,'UNKNOWN NAME') AS FirstName from DemoTable;

これにより、次の出力が生成されます-

+--------------+
| FirstName    |
+--------------+
| John         |
| UNKNOWN NAME |
| Adam         |
| UNKNOWN NAME |
+--------------+
4 rows in set (0.00 sec)

  1. MySQLのnull値に基づいて新しい列にカスタムテキストを表示しますか?

    まずテーブルを作成しましょう- mysql> create table DemoTable1953    (    StudentName varchar(20)    ); Query OK, 0 rows affected (0.00 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql> insert into DemoTable1953 values('Chris'); Query OK, 1 row affected (0.00 sec) mysql>

  2. MySQLのNULL値の場合は1を表示します

    まずテーブルを作成しましょう- mysql> create table DemoTable1963    (    Counter int    ); Query OK, 0 rows affected (0.00 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql> insert into DemoTable1963 values(20); Query OK, 1 row affected (0.00 sec) mysql> insert into DemoTable1963