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

เลือกและรวมกับการจัดกลุ่มใน MySQL?


ในการหาผลรวม ให้ใช้ฟังก์ชันรวม SUM() จากนั้นให้จัดกลุ่มโดยใช้ MySQL GROUP BY ให้เราสร้างตารางก่อน -

mysql> สร้างตาราง DemoTable -> ( -> ProductName varchar(20), -> ProductQuantity int, -> ProductPrice int -> );Query OK, 0 แถวได้รับผลกระทบ (0.63 วินาที)

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

mysql> แทรกลงในค่า DemoTable ('Product-1',2,50); ตกลง แบบสอบถาม 1 แถวได้รับผลกระทบ (0.16 วินาที) mysql> แทรกลงในค่า DemoTable ('Product-2',3,80); แบบสอบถาม ตกลง ได้รับผลกระทบ 1 แถว (0.10 วินาที)mysql> แทรกลงในค่า DemoTable ('Product-2',4,100); แบบสอบถามตกลง ได้รับผลกระทบ 1 แถว (0.11 วินาที) mysql> แทรกลงในค่า DemoTable ('Product-1',4,150);แบบสอบถามตกลง ได้รับผลกระทบ 1 แถว (0.11 วินาที)

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

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

สิ่งนี้จะทำให้เกิดผลลัพธ์ดังต่อไปนี้−

<ก่อนหน้า>+-------------+-----------+-------------- +| ชื่อสินค้า | ปริมาณสินค้า | ราคาสินค้า |+-------------+-----------+--------------+ | สินค้า-1 | 2 | 50 || สินค้า-2 | 3 | 80 || สินค้า-2 | 4 | 100 || สินค้า-1 | 4 | 150 |+-------------+-----------+--------------+ 4 แถวในชุด (0.00 วินาที)

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

mysql> เลือก *,sum(ProductQuantity*ProductPrice) เป็นยอดรวมจาก DemoTable -> จัดกลุ่มตามชื่อผลิตภัณฑ์

สิ่งนี้จะทำให้เกิดผลลัพธ์ดังต่อไปนี้−

<ก่อนหน้า>+-------------+-----------+-------------- +-------+| ชื่อสินค้า | ปริมาณสินค้า | สินค้าราคา | รวม |+-------------+-----------+--------------+ --------+| สินค้า-1 | 2 | 50 | 700 || สินค้า-2 | 3 | 80 | 640 |+-------------+-----------+--------------+ --------+2 แถวในชุด (0.00 วินาที)