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

วิธีใดเร็วที่สุดในการรับจำนวนแถวทั้งหมดสำหรับ MySQL Query


คุณสามารถใช้แบบสอบถามย่อยที่มีการรวม COUNT(*) เพื่อรับจำนวนแถวทั้งหมด

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

mysql> สร้างตาราง DemoTable ( StudentId int ไม่ใช่ NULL AUTO_INCREMENT PRIMARY KEY, StudentFirstName varchar(20), StudentAge int); แบบสอบถามตกลง 0 แถวได้รับผลกระทบ (0.48 วินาที)

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

mysql> แทรกลงในค่า DemoTable (StudentFirstName,StudentAge) ('John',23); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.15 วินาที) mysql> แทรกลงในค่า DemoTable (StudentFirstName, StudentAge) ('Larry', 21);แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.40 วินาที)mysql> แทรกลงใน DemoTable(StudentFirstName,StudentAge) ค่า ('Johnny',23);แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.43 วินาที)mysql> แทรกลงใน DemoTable (StudentFirstName,StudentAge) values('Chris',21);Query OK, 1 แถวได้รับผลกระทบ (0.18 วินาที)mysql> แทรกลงใน DemoTable(StudentFirstName,StudentAge) values('David',23);Query OK, 1 แถวได้รับผลกระทบ (0.20 วินาที)mysql> แทรกลงในค่า DemoTable(StudentFirstName,StudentAge) ('James',21); ตกลง ตกลง 1 แถวได้รับผลกระทบ (0.18 วินาที)mysql> แทรกลงในค่า DemoTable (StudentFirstName,StudentAge) ('Jace',24); ตกลง สืบค้น 1 แถวที่ได้รับผลกระทบ (0.12 วินาที)mysql> แทรกลงในค่า DemoTable (StudentFirstName,StudentAge) ('Mike',21); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.16 วินาที) mysql> แทรกลงในค่า DemoTable (StudentFirstName, StudentAge) ('Robert' ,25);แบบสอบถาม ตกลง 1 แถว ส่งผลกระทบ d (0.15 วินาที)mysql> แทรกลงในค่า DemoTable (StudentFirstName,StudentAge) ('Mike',22); แบบสอบถามตกลง ได้รับผลกระทบ 1 แถว (0.23 วินาที)

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

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

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

<ก่อนหน้า>+--------------------------------------+-----------+| รหัสนักศึกษา | StudentFirstName | StudentAge |+-----------+-----------+-----------+| 1 | จอห์น | 23 || 2 | แลร์รี่ | 21 || 3 | จอห์นนี่ | 23 || 4 | คริส | 21 || 5 | เดวิด | 23 || 6 | เจมส์ | 21 || 7 | เจซ | 24 || 8 | ไมค์ | 21 || 9 | โรเบิร์ต | 25 || 10 | ไมค์ | 22 |+-----------+--------------------------+-----------+10 แถวใน ตั้งค่า (0.00 วินาที)

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

mysql> เลือก StudentFirstName (เลือกจำนวน (*) จาก DemoTable) AS Total_Count จากขีดจำกัด DemoTable 10;

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

<ก่อนหน้า>+-------------+-------------+| StudentFirstName | Total_Count |+----------------------------------------------+| จอห์น | 10 || แลร์รี่ | 10 || จอห์นนี่ | 10 || คริส | 10 || เดวิด | 10 || เจมส์ | 10 || เจซ | 10 || ไมค์ | 10 || โรเบิร์ต | 10 || ไมค์ | 10 |+-----------+-------------+10 แถวในชุด (0.03 วินาที)