Toplamalar ve Grup İşlemleri

Java ile PostgreSQL Veritabanına Sorgu Yazma

Miller Trujillo

Staff Software Engineer

Toplamalar: COUNT, SUM, AVG

  • Birden fazla satırı tek bir sonuçta özetleyin

  • COUNT: satır sayısı

  • SUM: sayısal değerlerin toplamı
  • AVG: sayısal değerlerin ortalaması
SELECT COUNT(*) AS total_books,
       AVG(publication_year) AS avg_year
FROM books;
|total_books   |avg_year |
|--------------|---------|
|14            |1999.14  |
Java ile PostgreSQL Veritabanına Sorgu Yazma

Özetleme için GROUP BY

  • Toplamalar uygulamadan önce satırları gruplara ayırır
SELECT publication_year, COUNT(*) AS books_written
FROM books
GROUP BY publication_year;
| publication_year | books_written |
| ---------------- | ------------- |
| 2017             | 1             |
| 2003             | 1             |
| 1997             | 1             |
| 2018             | 3             |
| 2014             | 1             |
| 1960             | 1             |
Java ile PostgreSQL Veritabanına Sorgu Yazma

Birden Fazla Sütunla GROUP BY

  • Daha ayrıntılı analiz için birden fazla sütuna göre gruplayın
SELECT publication_year, c.name, COUNT(*) AS books_written
FROM books b
LEFT JOIN categories c on c.category_id = b.category_id 
GROUP BY publication_year, c.name;
| publication_year | name             | books_written |
| ---------------- | ---------------- | ------------- |
| 1951             | Fiction          | 1             |
| 1960             | Fiction          | 1             |
| 2018             | Computer Science | 3             |
| 1965             | Science Fiction  | 1             |
| 2010             | Fantasy          | 1             |
| 2003             | Computer Science | 1             |
Java ile PostgreSQL Veritabanına Sorgu Yazma

HAVING ile Grupları Filtreleme

  • WHERE gruplamadan önce satırları filtreler
  • HAVING toplamadan sonra grupları filtreler
SELECT publication_year, COUNT(*) AS books_written
FROM books b
GROUP BY publication_year
HAVING COUNT(*) > 2;
| publication_year | books_written |
| ---------------- | ------------- |
| 2018             | 3             |
Java ile PostgreSQL Veritabanına Sorgu Yazma

Java'da Toplamalar ve Gruplar

String query = """SELECT publication_year, COUNT(*) AS books_written FROM books b
    GROUP BY publication_year
    HAVING COUNT(*) > ?;""";
try (PreparedStatement pstmt = conn.prepareStatement(query)) {
    pstmt.setInt(1, 2); // 2'den fazla kitabı olan yılları filtrele

try (ResultSet rs = pstmt.executeQuery()) { while (rs.next()) { int year = rs.getInt("publication_year"); int count = rs.getInt("books_written"); } } }
| publication_year | books_written |
| ---------------- | ------------- |
| 2018             | 3             |
Java ile PostgreSQL Veritabanına Sorgu Yazma

Haydi pratik yapalım!

Java ile PostgreSQL Veritabanına Sorgu Yazma

Preparing Video For Download...