Birleştirmeler ve Alt Sorgularla Çalışma

Java ile PostgreSQL Veritabanına Sorgu Yazma

Miller Trujillo

Staff Software Engineer

Veriler birden fazla tabloda

  • books, authors, categories, book_reviews
  • Tablolar arasında veri birleştirme ihtiyacı

Kütüphane veritabanındaki ilişkiler

Java ile PostgreSQL Veritabanına Sorgu Yazma

Tabloları Birleştirme

String sql = "SELECT b.title, a.first_name, a.last_name " +
             "FROM books b " +

"INNER JOIN book_authors ba ON b.book_id = ba.book_id " + "INNER JOIN authors a ON ba.author_id = a.author_id " +
"WHERE b.publication_year > ?";
PreparedStatement pstmt = conn.prepareStatement(sql); pstmt.setInt(1, 2010); ResultSet rs = pstmt.executeQuery();
| title                                              | first_name | last_name |
| -------------------------------------------------- | ---------- | --------- |
| Effective Java                                     | Joshua     | Bloch     |
| Designing Data-Intensive Applications              | Martin     | Kleppmann |
Java ile PostgreSQL Veritabanına Sorgu Yazma

INNER ve LEFT JOIN

-- INNER JOIN: sadece eşleşenler
SELECT b.title, r.rating
FROM books b
INNER JOIN book_reviews r 
    ON b.book_id = r.book_id;
-- LEFT JOIN: tüm sol satırlar
SELECT b.title, r.rating
FROM books b
LEFT JOIN book_reviews r 
    ON b.book_id = r.book_id;

Inner ve Left Joinler

Java ile PostgreSQL Veritabanına Sorgu Yazma

Alt Sorgular

// En son yayımlanan kitabı çıkarma
String sql = "SELECT title FROM books " +
             "WHERE publication_year = ( " +

" SELECT MAX(publication_year) FROM books " + ")";
PreparedStatement pstmt = conn.prepareStatement(sql); ResultSet rs = pstmt.executeQuery();
| title                                              |
| -------------------------------------------------- |
| Effective Java                                     |
| Refactoring: Improving the Design of Existing Code |
Java ile PostgreSQL Veritabanına Sorgu Yazma

Parametreli Alt Sorgular

// Tüm "Fantastik" kitapları çıkarma
String sql = "SELECT title FROM books " +
             "WHERE category_id IN ( " +

" SELECT category_id FROM categories WHERE name = ? " + ")";
PreparedStatement pstmt = conn.prepareStatement(sql); pstmt.setString(1, "Fantasy"); ResultSet rs = pstmt.executeQuery();
| title                                    |
| ---------------------------------------- |
| The Way of Kings                         |
| Harry Potter and the Philosopher's Stone |
Java ile PostgreSQL Veritabanına Sorgu Yazma

StringBuilder

  • + ile string birleştirme yavaş ve okunması zordur
  • append() metni ekler, toString() sonucu döndürür
StringBuilder sb = new StringBuilder("SELECT * FROM ");

sb.append("books");
sb.append(" WHERE 1=1");
sb.toString(); // SELECT * FROM books WHERE 1=1
Java ile PostgreSQL Veritabanına Sorgu Yazma

Haydi pratik yapalım!

Java ile PostgreSQL Veritabanına Sorgu Yazma

Preparing Video For Download...