Tutorial Group By MySQL

Created at by Aris Munandar

Pada tutorial kali ini kita akan membahas tentang bagaimana melakukan GROUP BY MySQL, fungsi GROUP BY ini seperti namanya, digunakan untuk menyatukan data yang sama berdasarkan parameter grup yang dipilih sehingga seluruh data yang sama menjadi satu grup.

Berikut ini adalah contoh query penggunaan GROUP BY di MySQL…

SELECT
    col1, col2, ...
FROM
    table_name,
WHERE
    conditions
GROUP BY
    col1, col2,...

Dari contoh query diatas penggunaan GROUP BY MySQL digunakan setelah sintaks FROM dan juga WHERE namun jika anda menggunakan HAVING maka digunakan sebelum HAVING.

Didalam prakteknya query GROUP BY bisa disandingkan dengan fungsi agregat seperti SUM, AVG, MAX, MIN, dan juga COUNT yang biasanya digunakan untuk menghitung total keseluruhan data tertentu.

Tutorial Group By MySQL

Query Group By MySQL

Untuk lebih memahami bagaimana penggunaan GROUP BY maka kita memerlukan beberapa data sample sebagai bahan praktikum, jadi penulis sudah menyiapkan data table beserta dengan isinya yang bisa kita gunakan.

Buatlah dua buah tabel dengan query dibawah ini…

CREATE TABLE products(
	id INT NOT NULL PRIMARY KEY AUTO_INCREMENT,
	name VARCHAR(255) NOT NULL,
	price DECIMAL(10, 2) NOT NULL
);

CREATE TABLE orders(
    id INT NOT NULL PRIMARY KEY AUTO_INCREMENT,
    product_id INT NOT NULL,
    quantity INT NOT NULL,
    status VARCHAR(10) NOT NULL
);Code language: PHP (php)

Setelah itu tambahkan data ke dalam dua tabel yang sudah dibuat dengan menggunakan query dibawah ini.

INSERT INTO products(name, price) VALUES ('Mouse', 50000),
                                         ('Keyboard', 100000),
                                         ('Monitor', 1000000);

INSERT INTO orders(product_id, quantity, status) 
VALUES (1, 2, 'In Process'),
       (2, 1, 'Shipped'),
       (1, 3, 'Shipped'),
       (3, 1, 'Shipped'),
       (1, 1, 'In Process'),
       (3, 2, 'In Process'),
       (1, 5, 'Shipped'),
       (2, 2, 'Shipped');Code language: JavaScript (javascript)

Dari data diatas kita memiliki tabel orders dengan data yang apabila kita lakukan query SELECT dengan query dibawah ini…

SELECT * FROM orders

Maka akan menampilkan data sebagai berikut…

SELECT MySQL

Jika data dirasa sudah sesuai selanjutnya kita akan melakukan beberapa percobaan query penggunaan GROUP BY MySQL.

Query Dasar GROUP BY MySQL

Untuk menggunaan dasar query GROUP BY sangat mudah sekali, sebagai contoh kita akan mengelompokan data status, ada berapa data status di table orders dengan menggunakan query dibawah ini.

SELECT status FROM orders GROUP BY status

Dari query diatas maka akan menghasilkan data sebagai berikut…

Select Group by Basic

Dari penggunaan query diatas maka akan menghasilkan data seperti gambar diatas.

Query GROUP BY Dengan Fungsi Agregat

Fungsi agregat digunakan untuk menghitung nilai keseluruhan dari beberapa data untuk mengetahui jumlah yang diinginkan pada suatu data. Sebagia contoh query dibawah ini.

SELECT status, COUNT(*) AS total FROM orders GROUP BY statusCode language: PHP (php)

Query diatas digunakan untuk menghitung berapa data order pada setiap status yang ada didalam tabel orders.

Lalu pada contoh lainnya kita akan menghitung berapa total penjualan setiap produk yang tersedia pada table products dengan menggunakan JOIN antara table products dan juga orders.

Group By MySQL Relation

Pada diagram diatas adalah desain sederhana dari 2 tabel yang sebelumnya sudah kita buat, untuk selanjutnya kita coba lakukan penjumlahan berdasarkan jumlah quantity ditable order dengan price di table products.

Silahkan gunakan query dibawah ini…

SELECT 
    products.name, 
    products.price, 
    SUM(products.price*orders.quantity) AS amount 
FROM products
INNER JOIN orders ON orders.product_id = products.id
GROUP BY orders.product_idCode language: PHP (php)

Lalu hasil dari query diatas seperti pada gambar dibawah ini..

Select MySQL Join Group By

Group By Dengan Klausa Where

Selain itu kita juga dapat menentukan secara spesifik data mana yang ingin kita lakukan grouping sehingga data tertentu saja sesuai kebutuhan yang ingin kita tampilkan, anda dapat menggunakan klausa WHERE seperti dibawah ini.

SELECT products.name, products.price, SUM(products.price*orders.quantity) AS amount FROM products
INNER JOIN orders ON orders.product_id = products.id
WHERE orders.status = 'Shipped'
GROUP BY orders.product_idCode language: PHP (php)

Dari query diatas bisa dilihat, kita akan memfilter data yang hanya memiliki status = Shipped, sebagai contoh hasilnya pada gambar dibawah ini.

Select Group By Where MySQL

Group By Dengan Having

Sama seperti WHERE, penggunaan HAVING bertujuan untuk mengelompokan data tertentu berdasarkan kondisi yang diberikan, bedanya HAVING hanya bisa dilakukan setelah query GROUP BY, seperti contoh dibawah ini, kita akan mengeluarkan data yang harganya dibawah sama dengan 100000.

SELECT products.name, products.price, SUM(products.price*orders.quantity) AS amount FROM products
INNER JOIN orders ON orders.product_id = products.id
GROUP BY orders.product_id
HAVING products.price <= 100000Code language: PHP (php)

Maka hasilnya akan seperti gambar dibawah ini…

Select Group By Having

Penggunaan GROUP BY MySQL ini tentunya sangat bermanfaat untuk mengelompokan data tertentu sebagai kalkulasi dari beberapa data, tentunya akan semakin kompleks jika data yang ditangani jumlahnya sangat banyak.

Demikian tutorial ini semoga bermanfaat.

Comments

Congrats, you have the opportunity to be the first commenter on this article. Have questions or suggestions? Please leave a comment to start discussion.

Leave comment

Alamat email Anda tidak akan dipublikasikan. Required fields are marked *

news-1701

sabung ayam online

yakinjp

yakinjp

rtp yakinjp

slot thailand

yakinjp

yakinjp

yakin jp

yakinjp id

maujp

maujp

maujp

maujp

sabung ayam online

sabung ayam online

judi bola online

sabung ayam online

judi bola online

slot mahjong ways

slot mahjong

sabung ayam online

judi bola

live casino

sabung ayam online

judi bola

live casino

SGP Pools

slot mahjong

sabung ayam online

slot mahjong

SLOT THAILAND

post 138000916

post 138000917

post 138000918

post 138000919

post 138000920

post 138000921

post 138000922

post 138000923

post 138000924

post 138000925

post 138000926

post 138000927

post 138000928

post 138000929

post 138000930

post 138000931

post 138000932

post 138000933

post 138000934

post 138000935

cuaca 228000666

cuaca 228000667

cuaca 228000668

cuaca 228000669

cuaca 228000670

cuaca 228000671

cuaca 228000672

cuaca 228000673

cuaca 228000674

cuaca 228000675

cuaca 228000676

cuaca 228000677

cuaca 228000678

cuaca 228000679

cuaca 228000680

cuaca 228000681

cuaca 228000682

cuaca 228000683

cuaca 228000684

cuaca 228000685

cuaca 228000686

cuaca 228000687

cuaca 228000688

cuaca 228000689

cuaca 228000690

cuaca 228000691

cuaca 228000692

cuaca 228000693

cuaca 228000694

cuaca 228000695

cuaca 228000696

cuaca 228000697

cuaca 228000698

cuaca 228000699

cuaca 228000700

cuaca 228000701

cuaca 228000702

cuaca 228000703

cuaca 228000704

cuaca 228000705

cuaca 228000706

cuaca 228000707

cuaca 228000708

cuaca 228000709

cuaca 228000710

cuaca 228000711

cuaca 228000712

cuaca 228000713

cuaca 228000714

cuaca 228000715

cuaca 228000716

cuaca 228000717

cuaca 228000718

cuaca 228000719

cuaca 228000720

cuaca 228000721

cuaca 228000722

cuaca 228000723

cuaca 228000724

cuaca 228000725

cuaca 228000726

cuaca 228000727

cuaca 228000728

cuaca 228000729

cuaca 228000730

post 238000591

post 238000592

post 238000593

post 238000594

post 238000595

post 238000596

post 238000597

post 238000598

post 238000599

post 238000600

post 238000601

post 238000602

post 238000603

post 238000604

post 238000605

post 238000606

post 238000607

post 238000608

post 238000609

post 238000610

post 238000611

post 238000612

post 238000613

post 238000614

post 238000615

post 238000616

post 238000617

post 238000618

post 238000619

post 238000620

info 328000571

info 328000572

info 328000573

info 328000574

info 328000575

info 328000576

info 328000577

info 328000578

info 328000579

info 328000580

info 328000581

info 328000582

info 328000583

info 328000584

info 328000585

berita 428011471

berita 428011472

berita 428011473

berita 428011474

berita 428011475

berita 428011476

berita 428011477

berita 428011478

berita 428011479

berita 428011480

berita 428011481

berita 428011482

berita 428011483

berita 428011484

berita 428011485

berita 428011486

berita 428011487

berita 428011488

berita 428011489

berita 428011490

berita 428011491

berita 428011492

berita 428011493

berita 428011494

berita 428011495

berita 428011496

berita 428011497

berita 428011498

berita 428011499

berita 428011500

kajian 638000046

kajian 638000047

kajian 638000048

kajian 638000049

kajian 638000050

kajian 638000051

kajian 638000052

kajian 638000053

kajian 638000054

kajian 638000055

kajian 638000056

kajian 638000057

kajian 638000058

kajian 638000059

kajian 638000060

kajian 638000061

kajian 638000062

kajian 638000063

kajian 638000064

kajian 638000065

kajian 638000066

kajian 638000067

kajian 638000068

kajian 638000069

kajian 638000070

kajian 638000071

kajian 638000072

kajian 638000073

kajian 638000074

kajian 638000075

article 788000046

article 788000047

article 788000048

article 788000049

article 788000050

article 788000051

article 788000052

article 788000053

article 788000054

article 788000055

article 788000056

article 788000057

article 788000058

article 788000059

article 788000060

article 788000061

article 788000062

article 788000063

article 788000064

article 788000065

article 788000066

article 788000067

article 788000068

article 788000069

article 788000070

article 788000071

article 788000072

article 788000073

article 788000074

article 788000075

article 788000067

article 788000068

article 788000069

article 788000070

article 788000071

article 788000072

article 788000073

article 788000074

article 788000075

article 788000076

article 888000011

article 888000012

article 888000013

article 888000014

article 888000015

article 888000016

article 888000017

article 888000018

article 888000019

article 888000020

cuaca 988000001

cuaca 988000002

cuaca 988000003

cuaca 988000004

cuaca 988000005

cuaca 988000006

cuaca 988000007

cuaca 988000008

cuaca 988000009

cuaca 988000010

cuaca 988000011

cuaca 988000012

cuaca 988000013

cuaca 988000014

cuaca 988000015

news-1701
news-1701

sabung ayam online

yakinjp

yakinjp

rtp yakinjp

slot thailand

yakinjp

yakinjp

yakin jp

yakinjp id

maujp

maujp

maujp

maujp

sabung ayam online

sabung ayam online

judi bola online

sabung ayam online

judi bola online

slot mahjong ways

slot mahjong

sabung ayam online

judi bola

live casino

sabung ayam online

judi bola

live casino

SGP Pools

slot mahjong

sabung ayam online

slot mahjong

SLOT THAILAND

post 138000916

post 138000917

post 138000918

post 138000919

post 138000920

post 138000921

post 138000922

post 138000923

post 138000924

post 138000925

post 138000926

post 138000927

post 138000928

post 138000929

post 138000930

post 138000931

post 138000932

post 138000933

post 138000934

post 138000935

cuaca 228000666

cuaca 228000667

cuaca 228000668

cuaca 228000669

cuaca 228000670

cuaca 228000671

cuaca 228000672

cuaca 228000673

cuaca 228000674

cuaca 228000675

cuaca 228000676

cuaca 228000677

cuaca 228000678

cuaca 228000679

cuaca 228000680

cuaca 228000681

cuaca 228000682

cuaca 228000683

cuaca 228000684

cuaca 228000685

cuaca 228000686

cuaca 228000687

cuaca 228000688

cuaca 228000689

cuaca 228000690

cuaca 228000691

cuaca 228000692

cuaca 228000693

cuaca 228000694

cuaca 228000695

cuaca 228000696

cuaca 228000697

cuaca 228000698

cuaca 228000699

cuaca 228000700

cuaca 228000701

cuaca 228000702

cuaca 228000703

cuaca 228000704

cuaca 228000705

cuaca 228000706

cuaca 228000707

cuaca 228000708

cuaca 228000709

cuaca 228000710

cuaca 228000711

cuaca 228000712

cuaca 228000713

cuaca 228000714

cuaca 228000715

cuaca 228000716

cuaca 228000717

cuaca 228000718

cuaca 228000719

cuaca 228000720

cuaca 228000721

cuaca 228000722

cuaca 228000723

cuaca 228000724

cuaca 228000725

cuaca 228000726

cuaca 228000727

cuaca 228000728

cuaca 228000729

cuaca 228000730

post 238000591

post 238000592

post 238000593

post 238000594

post 238000595

post 238000596

post 238000597

post 238000598

post 238000599

post 238000600

post 238000601

post 238000602

post 238000603

post 238000604

post 238000605

post 238000606

post 238000607

post 238000608

post 238000609

post 238000610

post 238000611

post 238000612

post 238000613

post 238000614

post 238000615

post 238000616

post 238000617

post 238000618

post 238000619

post 238000620

info 328000571

info 328000572

info 328000573

info 328000574

info 328000575

info 328000576

info 328000577

info 328000578

info 328000579

info 328000580

info 328000581

info 328000582

info 328000583

info 328000584

info 328000585

berita 428011471

berita 428011472

berita 428011473

berita 428011474

berita 428011475

berita 428011476

berita 428011477

berita 428011478

berita 428011479

berita 428011480

berita 428011481

berita 428011482

berita 428011483

berita 428011484

berita 428011485

berita 428011486

berita 428011487

berita 428011488

berita 428011489

berita 428011490

berita 428011491

berita 428011492

berita 428011493

berita 428011494

berita 428011495

berita 428011496

berita 428011497

berita 428011498

berita 428011499

berita 428011500

kajian 638000046

kajian 638000047

kajian 638000048

kajian 638000049

kajian 638000050

kajian 638000051

kajian 638000052

kajian 638000053

kajian 638000054

kajian 638000055

kajian 638000056

kajian 638000057

kajian 638000058

kajian 638000059

kajian 638000060

kajian 638000061

kajian 638000062

kajian 638000063

kajian 638000064

kajian 638000065

kajian 638000066

kajian 638000067

kajian 638000068

kajian 638000069

kajian 638000070

kajian 638000071

kajian 638000072

kajian 638000073

kajian 638000074

kajian 638000075

article 788000046

article 788000047

article 788000048

article 788000049

article 788000050

article 788000051

article 788000052

article 788000053

article 788000054

article 788000055

article 788000056

article 788000057

article 788000058

article 788000059

article 788000060

article 788000061

article 788000062

article 788000063

article 788000064

article 788000065

article 788000066

article 788000067

article 788000068

article 788000069

article 788000070

article 788000071

article 788000072

article 788000073

article 788000074

article 788000075

article 788000067

article 788000068

article 788000069

article 788000070

article 788000071

article 788000072

article 788000073

article 788000074

article 788000075

article 788000076

article 888000011

article 888000012

article 888000013

article 888000014

article 888000015

article 888000016

article 888000017

article 888000018

article 888000019

article 888000020

cuaca 988000001

cuaca 988000002

cuaca 988000003

cuaca 988000004

cuaca 988000005

cuaca 988000006

cuaca 988000007

cuaca 988000008

cuaca 988000009

cuaca 988000010

cuaca 988000011

cuaca 988000012

cuaca 988000013

cuaca 988000014

cuaca 988000015

news-1701