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

MySQL GROUP BY และ CONCAT() เพื่อแสดงชื่อและนามสกุลที่ชัดเจน


ให้เราสร้างตารางก่อน -

mysql> สร้างตาราง DemoTable( FirstName varchar(100), LastName varchar(100));Query OK, 0 แถวได้รับผลกระทบ (0.92 วินาที)mysql> แก้ไขตาราง DemoTable เพิ่มดัชนี (FirstName,LastName); Query OK, 0 แถว ได้รับผลกระทบ (1.00 วินาที) บันทึก:0 รายการซ้ำ:0 คำเตือน:0

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

mysql> แทรกลงในค่า DemoTable ('Adam', 'Smith'); เคียวรีตกลง, 1 แถวได้รับผลกระทบ (0.73 วินาที)mysql> แทรกลงในค่า DemoTable ('Adam', 'Smith'); แบบสอบถามตกลง 1 แถว ได้รับผลกระทบ (1.17 วินาที) mysql> แทรกลงในค่า DemoTable ('John', 'Doe'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.19 วินาที) mysql> แทรกลงในค่า DemoTable ('Carol', 'Taylor'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.25 วินาที) mysql> แทรกลงในค่า DemoTable ('John', 'Doe'); แบบสอบถามตกลง ได้รับผลกระทบ 1 แถว (0.66 วินาที)

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

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

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

<ก่อนหน้า>+-----------+----------+| ชื่อจริง | นามสกุล |+-----------+----------+| อดัม | สมิธ || อดัม | สมิธ || แครอล | เทย์เลอร์ || จอห์น | โด || จอห์น | Doe |+-----------+----------+5 แถวในชุด (0.00 วินาที)

ต่อไปนี้เป็นแบบสอบถามเพื่อรวมชื่อและนามสกุลที่แตกต่างกัน -

mysql> เลือก concat(FirstName,' ',LastName) เป็นชื่อที่รวมจาก DemoTablegroup โดย LastName,FirstName;

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

<ก่อนหน้า>+-------------+| รวมชื่อ |+-------------+| อดัม สมิธ || แครอล เทย์เลอร์ || John Doe |+-------------+3 แถวในชุด (0.00 วินาที)