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

แบบสอบถาม MySQL เพื่อนับแถวด้วยคอลัมน์เฉพาะ?


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

mysql> สร้างตาราง DemoTable841 ( Id int ไม่ใช่ NULL AUTO_INCREMENT PRIMARY KEY, ค่า varchar (100)); เคียวรีตกลง 0 แถวได้รับผลกระทบ (0.67 วินาที)

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

mysql> แทรกลงในค่า DemoTable841(Value) ('X'); เคียวรีตกลง 1 แถวได้รับผลกระทบ (0.19 วินาที)mysql> แทรกลงในค่า DemoTable841(Value) ('Y'); เคียวรีตกลง 1 แถวได้รับผลกระทบ ( 0.39 วินาที) mysql> แทรกลงในค่า DemoTable841 (ค่า) ('Y'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (1.62 วินาที) mysql> แทรกลงในค่า DemoTable841 (ค่า) ('Z'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ ( 0.14 วินาที) mysql> แทรกลงในค่า DemoTable841 (ค่า) ('X'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.81 วินาที) mysql> แทรกลงในค่า DemoTable841 (ค่า) ('Z'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ ( 0.26 วินาที)

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

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

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

<ก่อนหน้า>+----+-------+| รหัส | ความคุ้มค่า |+---+-------+| 1 | X || 2 | Y || 3 | Y || 4 | Z || 5 | X || 6 | Z |+----+-------+6 แถวในชุด (0.00 วินาที)

ต่อไปนี้เป็นแบบสอบถามเพื่อนับแถวที่มีคอลัมน์เฉพาะใน MySQL -

mysql> เลือก Value,Concat(COUNT(Value),' Times') จากกลุ่ม DemoTable841 ตามค่า

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

<ก่อนหน้า>+-------+------------------------------+| ความคุ้มค่า | Concat(COUNT(Value),' Times') |+------+----------------------------- ---+| X | 2 ครั้ง || Y | 2 ครั้ง || Z | 2 ครั้ง |+-------+-------------------------------+3 แถวในชุด (0.04 วินาที)