Teknomers | Dünyadan Güncel Teknoloji | Oyun | Müzik | Film | Spor HaberleriTeknomers | Dünyadan Güncel Teknoloji | Oyun | Müzik | Film | Spor HaberleriTeknomers | Dünyadan Güncel Teknoloji | Oyun | Müzik | Film | Spor Haberleri
Yazı Tipi BoyutlandırıcıAa
  • Anasayfa
  • Teknoloji
    • Siber Güvenlik
    • Yapay Zeka
    • Donanım
    • Bilim
  • Yazılım
  • Savunma & İstihbarat
  • Oyun
  • Yaşam
    • Finans
    • Sinema
    • Dünyadan Haberler
  • İş Birliği
Okuma: Doctrine QueryBuilder Yöntemleri Hızlı Referans Kılavuzu
Paylaş
Yazı Tipi BoyutlandırıcıAa
Teknomers | Dünyadan Güncel Teknoloji | Oyun | Müzik | Film | Spor HaberleriTeknomers | Dünyadan Güncel Teknoloji | Oyun | Müzik | Film | Spor Haberleri
Ara
Bizi Takip Et
  • Hakkımızda
  • Gizlilik politikası
  • Tanıtım Yazısı ve Backlink Hizmeti
© 2026 Teknomers. All Rights Reserved.

Anasayfa » Doctrine QueryBuilder Yöntemleri Hızlı Referans Kılavuzu

Yazılım

Doctrine QueryBuilder Yöntemleri Hızlı Referans Kılavuzu

teknomers
Son güncelleme: 22 Mart 2026 09:59
teknomers
Paylaş
Paylaş

Doctrine QueryBuilder Kılavuzu

Bu kılavuz, Doctrine QueryBuilder ile çalışırken kullanabileceğiniz temel yöntemleri ve en iyi uygulamaları içermektedir. Aşağıdaki bölümler, SELECT, JOIN, WHERE gibi komutlardan daha karmaşık CTE, UNION, ve önbellekleme gibi konulara kadar geniş bir yelpazeyi kapsamaktadır. İşte detaylar:

İçerik Başlıkları:

  • SELECT: Alan seçim ve DISTINCT seçenekleri;
  • FROM & JOIN: Tablo ayarı ve join türleri (INNER, LEFT, RIGHT);
  • WHERE/HAVING: AND/OR mantığı ile koşullar;
  • GROUP/ORDER: Gruplama ve sıralama, sıfırlama kontrolleriyle;
  • CRUD: INSERT, UPDATE, DELETE işlemleri;
  • Advanced: UNION, CTE, LIMIT/OFFSET, önbellekleme.

1. SELECT

select(string ...$expressions) — SELECT alanlarını tanımlar, önceki seçimleri geçersiz kılar.

// SELECT u.id, u.name, u.email FROM ...
$qb->select('u.id', 'u.name', 'u.email');

addSelect(string $expression, string ...$expressions) — Mevcut SELECT ifadesine alanlar ekler.

// SELECT u.id, p.title, p.content FROM ...
$qb->select()->addSelect(, );

distinct(bool $distinct = true) — Tekrar eden satırların ortadan kaldırılması için DISTINCT ekler.

// SELECT DISTINCT u.city FROM ...
$qb->select()->distinct();

2. FROM & JOIN

from(string $table, ?string $alias = null) — FROM ifadesinde ana tabloyu tanımlar ve isteğe bağlı olarak bir takma ad atar.

// FROM users u
$qb->from(, );

join(string $fromAlias, string $join, string $alias, ?string $condition = null) — Tablolar arasında INNER JOIN oluşturur ve sadece her iki tarafta eşleşen satırları döndürür.

// INNER JOIN posts p ON p.user_id = u.id
$qb->from(, )->join(, , , );

3. WHERE/HAVING

where(string|CompositeExpression $predicate, ...$predicates) — Yeni koşullarla WHERE ifadesini tamamen ayarlar veya değiştirir.

// WHERE u.active = 1 AND u.role="admin"
$qb->select()
   ->from(, )
   ->where()
   ->setParameter(, 1)
   ->setParameter(, );

4. GROUP/ORDER

groupBy(string $expression, ...$expressions) — Belirtilen sütunlarda eşleşen değerleri gruplayarak, genellikle toplama işlevleri ile kullanılır.

// GROUP BY u.city - kullanıcıları konumlarına göre grupla
$qb->select()
   ->from(, )
   ->groupBy();

5. CRUD

insert(string $table) — QueryBuilder‘ı INSERT moduna geçirir ve yeni kayıt oluşturmak için hedef tabloyu ayarlar.

// INSERT INTO users (name, email) VALUES ...
$qb->insert()
   ->setValue(, )
   ->setValue(, )
   ->setParameter(, )
   ->setParameter(, );

6. UNION (DBAL 4.x)

union(string|QueryBuilder $part) — Birleştirerek sonuçları birleştirmek için ilk UNION bloğunu ekler.

// (SELECT u.id FROM users u) UNION (SELECT a.id FROM admins a)
$qb1 = $entityManager->createQueryBuilder()
    ->select()
    ->from(, );
        
$qb2 = $entityManager->createQueryBuilder()
    ->select()
    ->from(, );
        
$qb1->union($qb2->getDQL());

7. CTE

with(string $name, string|QueryBuilder $part, ?array $columns = null) — Birden fazla referans kullanmak için adlandırılmış bir alt sorgu oluşturur.

// WITH active_users AS (SELECT * FROM users WHERE active = 1)
$qb->with(, )
   ->select()
   ->from(, )
   ->leftJoin(, , , )
   ->groupBy();

8. LIMIT/OFFSET

setFirstResult(int $firstResult) — İlk N satırı atlamak için OFFSET ayarlar, sayfalama için kullanışlıdır.

// İlk 20 kullanıcıyı atla (sayfa 3, 20 sonuç)
$qb->select()
   ->from(, )
   ->setFirstResult(20)
   ->setMaxResults(20);

9. Parametreler

setParameter(int|string $key, mixed $value, $type = ParameterType::STRING) — Tek bir parametreyi bağlar; SQL enjeksiyonunu önler.

// İsimli parametre :userId
$qb->where()
   ->setParameter(, 123, ParameterType::INTEGER);

10. Çalıştırma

executeQuery(): Result — SELECT sorgularını yürütür ve bir Result nesnesi döndürür.

// SELECT işlemi yap ve sonucu al
$result = $qb->select()
   ->from(, )
   ->where()
   ->setParameter(, 1)
   ->getQuery()
   ->executeQuery();

Bitti!

Bu kılavuz, tüm temel Doctrine QueryBuilder yöntemlerini kapsayan 12 pratik bölüm içermektedir. Temiz, etkili SQL sorguları yazma konusunda size yardımcı olmayı amaçlamaktadır.

Kaynak: Orijinal Makale

Contents
  • Doctrine QueryBuilder Kılavuzu
    • İçerik Başlıkları:
    • 1. SELECT
    • 2. FROM & JOIN
    • 3. WHERE/HAVING
    • 4. GROUP/ORDER
    • 5. CRUD
    • 6. UNION (DBAL 4.x)
    • 7. CTE
    • 8. LIMIT/OFFSET
    • 9. Parametreler
    • 10. Çalıştırma
  • Bitti!
Laravel Güvenliğini, Performansını ve SEO’yu Geliştiren En İyi Paketler
Hervey Bay’de Araç Yıkama Hizmetleri | Profesyonel ve Uygun Fiyatlı Araç Temizliği
Laravel Queue ve defer(): Her Birini Ne Zaman Kullanmalı (Laravel 11, 12 ve 13)
Gün 8: Verinin Hayatını Görmek İçin Bir Zaman Çizelgesi Oluşturdum
Composer yalnızca bir konsol uygulamasıdır
Bu Makaleyi Paylaş
Facebook Bağlantıyı Kopyala Yazdır
Paylaş
Önceki Makale AI tokenları yeni bir imza bonusu mu yoksa iş yapmanın maliyeti mi?
Sonraki Makale Dünya Kupası Turistleri İçin Meksiko’nun Xoli Chatbot’u ile Şehri Keşfedin

Sanal Medya

FacebookBeğen
452Takip Et
PinterestSabitle
237Takip Et

Son Eklenenler

Final Fantasy VII Üçlemesi Son Perdeyi Revelasyon ile Açıyor
Liste
Acil! Toshiba ve Muji websitelerinde şüpheli giriş uyarıları ortaya çıktı
Siber Güvenlik
Tatiliniz İçin 13 Çevre Dostu Paketleme İpucu ile Fark Yaratın
Genel
Kurucular VC korku hikayelerini paylaşıyor, bazıları isimleri veriyor
Genel
Control Resonant devam niteliğinde ama aynı zamanda bir başlangıç noktası mı?
Liste
Anthropic, Claude AI’nin beklenenden hızlı geliştiğini uyardı
Donanım
//

Siber güvenlik, yapay zeka ve savunma sanayiinden; finans ve sinema dünyasına uzanan geniş bir yelpaze. Teknomers; teknoloji, strateji ve yazılım dünyasını sade bir dille sizlerle buluşturuyor.

Kurumsal

  • Hakkımızda
  • Gizlilik politikası
  • Tanıtım Yazısı ve Backlink Hizmeti

Kategoriler

  • Teknoloji
  • Oyun
  • Sinema
  • Siber Güvenlik
  • Bilim
  • Finans
  • Dünyadan Güncel Haberler

Populer

  • TV'de Ücretsiz İzlenebilen Şifresiz Erotik Kanallar (2025 Güncel Frekans Listesi)

  • The Last of Us PC Kontrolleri: Hızlı Silah Değiştirme ve Tüm Tuşlar (2025)

  • Hogwarts Legacy'de Odaklanma İksiri Nasıl Yapılır?

Teknomers | Dünyadan Güncel Teknoloji | Oyun | Müzik | Film | Spor HaberleriTeknomers | Dünyadan Güncel Teknoloji | Oyun | Müzik | Film | Spor Haberleri
Bizi Takip Et
© 2026 Teknomers. All Rights Reserved.
Welcome Back!

Sign in to your account

Kullanıcı Adı veya E-posta Adresi
Şifre

Şifrenizi mi unuttunuz?