Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> MySQL

กรณีเมื่อ column1 เป็น NULL แล้ว NULL ELSE คอลัมน์ที่ 2 ลงท้ายด้วย MySQL


สำหรับสิ่งนี้ คุณสามารถใช้คำสั่ง CASE ให้เราสร้างตารางก่อน-

mysql> สร้างตาราง DemoTable -> ( -> Name varchar(20), -> Marks1 int, -> Marks2 int -> );Query OK, 0 แถวได้รับผลกระทบ (0.72 วินาที)

แทรกบางระเบียนในตารางโดยใช้คำสั่ง insert-

mysql> แทรกลงในค่า DemoTable ('Chris',45,null);Query OK, 1 แถวได้รับผลกระทบ (0.14 วินาที)mysql> แทรกลงในค่า DemoTable ('David',null,78);Query OK, 1 แถว ได้รับผลกระทบ (0.16 วินาที) mysql> แทรกลงในค่า DemoTable ('Bob',67,98); แบบสอบถามตกลง ได้รับผลกระทบ 1 แถว (0.14 วินาที)

แสดงระเบียนทั้งหมดจากตารางโดยใช้คำสั่ง select -

mysql> เลือก *จาก DemoTable;

สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -

<ก่อนหน้า>+-------+---------+-------+| ชื่อ | Marks1 | Marks2 |+-------+---------+-------+| คริส | 45 | NULL || เดวิด | NULL | 78 || บ๊อบ | 67 | 98 |+-------+---------+-------+3 แถวในชุด (0.00 วินาที)

ต่อไปนี้คือข้อความค้นหาที่จะใช้ CASE WHEN -

mysql> เลือก *, -> (กรณีที่ Marks1 เป็นโมฆะแล้ว null อื่น Marks2 end ) เป็นค่า -> จาก DemoTable;

สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ -

<ก่อนหน้า>+-------+---------+---------+-------+| ชื่อ | Marks1 | Marks2 | ค่า |+-------+---------+---------+-------+| คริส | 45 | NULL | NULL || เดวิด | NULL | 78 | NULL || บ๊อบ | 67 | 98 | 98 |+-------+---------+---------+-------+3 แถวในชุด (0.00 วินาที)