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

แบบสอบถาม MySQL เพื่อนับค่า ID ที่ซ้ำกันและแสดงผลลัพธ์ในคอลัมน์แยกต่างหาก


ในการนับค่า ID ที่ซ้ำกัน ให้ใช้ฟังก์ชันรวม COUNT() และ GROUP BY ให้เราสร้างตารางก่อน -

mysql> สร้างตาราง DemoTable( Id int ชื่อ varchar(100)); ตกลง ตกลง 0 แถวได้รับผลกระทบ (1.30 วินาที)

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

mysql> แทรกลงในค่า DemoTable (50,'Chris'); แบบสอบถามตกลง, 1 แถวได้รับผลกระทบ (0.19 วินาที) mysql> แทรกลงในค่า DemoTable (51, 'David'); แบบสอบถามตกลง, 1 แถวได้รับผลกระทบ (0.15 วินาที )mysql> แทรกลงในค่า DemoTable (51, 'Mike'); แบบสอบถามตกลง, 1 แถวได้รับผลกระทบ (0.18 วินาที) mysql> แทรกลงในค่า DemoTable (50, 'Sam'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.17 วินาที) 

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

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

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

<ก่อนหน้า>+------+-------+| รหัส | ชื่อ |+------+-------+| 50 | คริส || 51 | เดวิด || 51 | ไมค์ || 50 | แซม |+------+-------+4 แถวในชุด (0.00 วินาที)

ต่อไปนี้เป็นแบบสอบถามเพื่อแสดงจำนวนค่า ID ที่ซ้ำกันในคอลัมน์ใหม่ -

mysql> เลือก Id,count(Name) เป็น Count from DemoTable group by Id;

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

<ก่อนหน้า>+------+-------+| รหัส | นับ |+------+-------+| 50 | 2 || 51 | 2 |+------+-------+2 แถวในชุด (0.00 วินาที)