Computer >> 컴퓨터 >  >> 프로그램 작성 >> MySQL

필드를 선택하고 null인 경우 MySQL로 다른 필드를 선택하시겠습니까?

<시간/>

이를 위해 COALESCE()를 사용합니다. 먼저 테이블을 생성하겠습니다 -

mysql> create table DemoTable1470
   -> (
   -> FirstName varchar(20),
   -> Age int
   -> );
Query OK, 0 rows affected (0.57 sec)

삽입 명령을 사용하여 테이블에 일부 레코드 삽입 -

mysql> insert into DemoTable1470 values('Robert',23);
Query OK, 1 row affected (0.09 sec)
mysql> insert into DemoTable1470 values('Bob',NULL);
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable1470 values(NULL,25);
Query OK, 1 row affected (0.15 sec)

select 문을 사용하여 테이블의 모든 레코드 표시 -

mysql> select * from DemoTable1470;

이것은 다음과 같은 출력을 생성합니다 -

+-----------+------+
| FirstName | Age  |
+-----------+------+
| Robert    |   23 |
| Bob       | NULL |
| NULL      |   25 |
+-----------+------+
3 rows in set (0.00 sec)

다음은 필드를 선택하는 쿼리이며 null이면 다른 필드를 선택합니다. -

mysql> select coalesce(FirstName,Age) as FirstNameOrAgeValue from DemoTable1470;

이것은 다음과 같은 출력을 생성합니다 -

+---------------------+
| FirstNameOrAgeValue |
+---------------------+
| Robert              |
| Bob                 |
| 25                  |
+---------------------+
3 rows in set (0.00 sec)