Ընտրեք դաշտ, իսկ եթե այն զրոյական է, MySQL-ով ընտրե՞ք մեկ այլ դաշտ:


Դրա համար օգտագործեք COALESCE(): Եկեք նախ ստեղծենք աղյուսակ.

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

Տեղադրեք որոշ գրառումներ աղյուսակում՝ օգտագործելով insert հրամանը.

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)

Հետևյալ հարցումն է՝ դաշտ ընտրելու համար, և եթե այն զրոյական է, ընտրեք մեկ այլ.

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

Սա կստեղծի հետևյալ արդյունքը.

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