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

เราจัดกลุ่มตามคอลัมน์เดียวและเลือกข้อมูลทั้งหมดใน MySQL ได้หรือไม่


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

mysql> สร้างตาราง groupByOneSelectAll -> ( -> StudentDetails varchar(100), -> StudentName varchar(100) -> ); ตกลง ตกลง 0 แถวได้รับผลกระทบ (0.91 วินาที)

ต่อไปนี้เป็นแบบสอบถามเพื่อแทรกบางระเบียนในตารางโดยใช้คำสั่งแทรก -

mysql> แทรกลงใน groupByOneSelectAll values('StudentFirstName','John');Query OK, 1 แถวได้รับผลกระทบ (0.14 วินาที)mysql> แทรกลงใน groupByOneSelectAll values('StudentFirstName','Chris');Query OK, 1 แถว ได้รับผลกระทบ (0.21 วินาที) mysql> แทรกลงใน groupByOneSelectAll ค่า ('StudentFirstName', 'Robert'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.65 วินาที) mysql> แทรกลงใน groupByOneSelectAll ค่า ('StudentFirstName', 'Bob'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.13 วินาที) mysql> แทรกลงใน groupByOneSelectAll ค่า ('StudentFirstName','David'); ตกลง ตกลง 1 แถวได้รับผลกระทบ (0.15 วินาที)

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

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

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

<ก่อนหน้า>+-------------+-------------+| รายละเอียดนักศึกษา | ชื่อนักเรียน |+-------------+-------------+| StudentFirstName | จอห์น || StudentFirstName | คริส || StudentFirstName | โรเบิร์ต || StudentFirstName | บ๊อบ || StudentFirstName | David |+-----------+-------------+5 แถวในชุด (0.00 วินาที)

ต่อไปนี้เป็นแบบสอบถามเพื่อจัดกลุ่มตามคอลัมน์เดียว -

mysql> เลือก StudentDetails,group_concat(StudentName) จาก groupByOneSelectAll groupby StudentDetails;

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

<ก่อนหน้า>+------------------------------------------------------------- ---+| รายละเอียดนักศึกษา | group_concat(StudentName) |+-----------------+------------------------- ----+| StudentFirstName | จอห์น คริส โรเบิร์ต บ๊อบ เดวิด |+--------------------------+-------------------------- ---------+1 แถวในชุด (0.05 วินาที)