Linux ­Kurulu­m ve Y­onetim­i
  • Döküman Hakkında
  • Linux ve GNU'nun Geçmişi
    • CentOS, Debian ve FreeBSD Ana Sürümlerin Farkları
  • Temel Komutlar
    • Temel Terminal Komutları
    • Yardım Dosyaları
    • Dosya İzinleri, Yetkiler, Kullanıcılar ve Gruplar
    • Dosya Düzenleme Araçları
      • nano ve pico
      • vi
    • Sıkıştırılmış Dosyalar
  • Standart Girdi ve Çıktı
    • Standart Çıktı
    • Standart Girdi
    • UNIX Pipeline
    • Olmazsa Olmaz: stdio.h
    • Standart Hata ve File Descriptor
    • Forkbomb
    • Named Pipe
  • Gelişmiş Terminal Komutları
    • Tarih ve Saat Ayarlama
    • Sistem Yükünü İzleme
    • patch ve diff
    • xargs
    • awk ve sed
    • egrep ve Regular Expressions
    • rename
    • Imagemagick ve Görüntü Dosyaları
    • wget
    • Python ile Dosya Sunuculuğu
  • Temel Dağıtımlar
    • RHEL Tabanlı (CentOS, Rocky, Alma)
      • rpm Paketleri
      • DNF Paket Yöneticisi
      • Repo Ayarları
      • Network Ayarları
    • Debian
      • deb Paketleri
      • apt Paket Yöneticisi
      • Repo Ayarları
      • Network Ayarları
    • FreeBSD
      • Ports ve pkg Yönetimi
      • Güncelleme Teknikleri
      • Network Ayarları
    • Arch Linux
      • pacman ve AUR
      • Network Ayarları
    • Ortak Network Dosyaları
  • SSH
    • Uzak Sunucuya Bağlanma
    • sshd Sunucu Ayarları
    • Private ve Public Anahtarlar
    • Güvenli Dosya Aktarımı
    • sshfs
  • Kernel Boot
    • Sunucu Başlangıcına Genel Bakış
    • Çekirdeğin Yüklenmesi ve Boot Seçenekleri
    • Çekirdek Parametreleri
    • Bootloader Nedir?
  • User Space
    • Başlangıç: Init
    • Init Versiyonunu Belirlemek
    • System V
      • Servislerin Yönetimi
      • Çalışma Seviyeleri (Run Levels)
      • Örnek System V Servis Oluşturma
    • systemd
      • Servislerin Yönetimi
      • Birimler ve Birim Tipleri
      • Örnek systemd Servis Oluşturma
    • Acil Durumlar ve Tek Kullanıcı Modu
  • BASH Programlama
    • Döngüler ve Diğer Kontrol Yöntemleri
    • Menüler
  • Log Dosyaları
    • Log İnceleme ve Filtreleme
  • İnternet Servisleri
    • Bir sayfanın İnternetteki Serüveni
    • Nameserver Servisleri
    • Apache
    • PHP-FPM
    • FTP/FTPS/SFTP
      • vsftpd
      • ProFTPD
      • SFTP
      • Komut Satırından ftp Kullanımı
  • Zamanlanmış Görevler
    • crontab
    • at
  • Veritabanı
    • MySQL
      • MySQL Kurulumu
      • MySQL Servisini Çalıştırmak
      • Veritabanı ve Tablo oluşturmak
      • SQL Tablosuna Veri Eklemek
      • Temel SQL Sorgularına Giriş
        • Birinci bölüm
      • mysqldump ile yedekleme
      • Replikasyon teknikleri
      • Yedekleri içeri alma
    • PostgreSQL
      • PostgreSQL Kurulumu
      • Temel Yapılandırma
      • Temel Kullanım
    • MongoDB
      • MongoDB Kurulumu
      • Temel Yapılandırma
      • Temel Kullanım
    • Redis
      • Redis Kurulumu
      • Temel Yapılandırma
      • Temel Kullanım
  • Temel Network Yapılandırması
  • Gelişmiş Network Komutları
    • ip
    • ifconfig
    • route
    • ping
    • traceroute
    • dig
    • nslookup
    • netcat
    • nmap
    • tcpdump
    • Wireshark (Giriş)
    • Bantgenişliği Ölçümü
  • Güvenlik
    • Firewalld
    • IPTables
      • Temel İzinler
      • IP ve Port Engelleme
    • selinux
  • Disk Sistemleri
    • ext
    • zfs
    • lvm
  • RAID
    • RAID Biçimleri
    • Verinin Disklere Yayılması
    • Cache
    • Terimler ve Tavsiyeler
  • Örnek Kurulumlar ve Modern Yaklaşımlar
    • CentOS 7 Tam Sistem Kurulumu (Arşiv)
    • AlmaLinux ile Hosting Ortamı Kurulumu
    • Ubuntu ile Hosting Ortamı Kurulumu
    • Modern Hosting Yaklaşımları (PaaS, Coolify vb.)
  • Konteynerleştirme (Docker / Podman)
  • Yapılandırma Yönetimi (Ansible)
  • İzleme ve Uyarı (Prometheus / Grafana)
  • Nginx Web Sunucusu
  • Kubernetes (Giriş)
  • PCI-DSS ve Linux Sistemleri
  • İndeks
  • Kaynaklar
Powered by GitBook
On this page
  • Tüm Sütunları Seçme (SELECT *)
  • Belirli Sütunları Seçme
  • Satırları Filtreleme (WHERE)
  • Sonuçları Sıralama (ORDER BY)
  • Sonuç Sayısını Sınırlama (LIMIT)
  1. Veritabanı
  2. MySQL
  3. Temel SQL Sorgularına Giriş

Birinci bölüm

SELECT komutu, veritabanı tablolarından veri çekmek için kullanılır. En temel SQL komutlarından biridir ve çeşitli yan tümceler (clauses) ile birlikte kullanılarak veriyi filtrelemek, sıralamak ve sınırlamak mümkündür.

Bu bölümde, önceki adımlarda oluşturduğumuz company veritabanındaki member tablosunu kullanarak temel SELECT sorgularını inceleyeceğiz.

Örnek member tablosu içeriği:

+----+------------+-----------+----------------------+------------+---------------------+---------------------+
| id | first_name | last_name | email                | birthday   | created_at          | updated_at          |
+----+------------+-----------+----------------------+------------+---------------------+---------------------+
|  1 | Yaşar      | Celep     | celep@veriteknik.com | 1996-12-23 | 2025-03-28 06:18:00 | 2025-03-28 06:18:00 |
|  2 | Ahmet      | Yılmaz    | ahmet@example.com    | 1990-05-15 | 2025-03-28 06:18:30 | 2025-03-28 06:18:30 |
|  3 | Ayşe       | Kaya      | ayse.kaya@example.net| NULL       | 2025-03-28 06:18:30 | 2025-03-28 06:18:30 |
|  4 | Mehmet     | Demir     | mehmet@example.org   | 1985-01-30 | 2025-03-28 06:18:30 | 2025-03-28 06:18:30 |
+----+------------+-----------+----------------------+------------+---------------------+---------------------+

Tüm Sütunları Seçme (SELECT *)

Bir tablodaki tüm sütunları ve tüm satırları getirmek için SELECT * FROM <tablo_adı>; kullanılır:

SELECT * FROM member; 

Bu komut yukarıdaki örnek tablonun tamamını döndürür.

Belirli Sütunları Seçme

Sadece istediğiniz sütunları getirmek için, sütun adlarını virgülle ayırarak belirtin:

SELECT first_name, last_name, email FROM member;

Örnek Çıktı:

+------------+-----------+----------------------+
| first_name | last_name | email                |
+------------+-----------+----------------------+
| Yaşar      | Celep     | celep@veriteknik.com |
| Ahmet      | Yılmaz    | ahmet@example.com    |
| Ayşe       | Kaya      | ayse.kaya@example.net|
| Mehmet     | Demir     | mehmet@example.org   |
+------------+-----------+----------------------+

Satırları Filtreleme (WHERE)

Belirli koşullara uyan satırları seçmek için WHERE yan tümcesi kullanılır. Çeşitli karşılaştırma ve mantıksal operatörler kullanılabilir:

  • Eşitlik (=):

    SELECT * FROM member WHERE first_name = 'Ahmet';
  • Eşit Değil (!= veya <>):

    SELECT email FROM member WHERE first_name != 'Ayşe';
  • Karşılaştırma (>, <, >=, <=):

    SELECT first_name, last_name FROM member WHERE birthday < '1995-01-01';
  • Desen Eşleştirme (LIKE): Metin içinde kalıp aramak için kullanılır.

    • %: Sıfır veya daha fazla karakterle eşleşir.

    • _: Tek bir karakterle eşleşir.

    -- E-postası '.com' ile bitenler
    SELECT * FROM member WHERE email LIKE '%.com'; 
    -- Adı 'A' ile başlayanlar
    SELECT * FROM member WHERE first_name LIKE 'A%'; 
    -- Soyadının ikinci harfi 'e' olanlar
    SELECT * FROM member WHERE last_name LIKE '_e%'; 
  • Liste İçinde (IN): Belirtilen değerlerden herhangi birine sahip olanları seçer.

    SELECT * FROM member WHERE id IN (1, 3);
  • Aralık (BETWEEN ... AND ...): Belirtilen aralıktaki değerlere sahip olanları seçer (sınırlar dahil).

    SELECT * FROM member WHERE birthday BETWEEN '1990-01-01' AND '1999-12-31';
  • Boş Değer Kontrolü (IS NULL, IS NOT NULL):

    -- Doğum tarihi girilmemiş olanlar
    SELECT * FROM member WHERE birthday IS NULL; 
    -- E-postası girilmiş olanlar
    SELECT * FROM member WHERE email IS NOT NULL; 
  • Koşulları Birleştirme (AND, OR):

    -- Adı 'Ahmet' VE soyadı 'Yılmaz' olanlar
    SELECT * FROM member WHERE first_name = 'Ahmet' AND last_name = 'Yılmaz'; 
    -- ID'si 1 VEYA 4 olanlar
    SELECT * FROM member WHERE id = 1 OR id = 4; 
    -- 1990'dan önce doğmuş VE e-postası '.org' ile bitenler
    SELECT * FROM member WHERE birthday < '1990-01-01' AND email LIKE '%.org'; 

Sonuçları Sıralama (ORDER BY)

Sonuçları belirli bir veya daha fazla sütuna göre sıralamak için ORDER BY kullanılır.

  • Artan Sıralama (ASC - Varsayılan):

    SELECT * FROM member ORDER BY last_name ASC;
    -- veya sadece:
    SELECT * FROM member ORDER BY last_name;
  • Azalan Sıralama (DESC):

    SELECT * FROM member ORDER BY birthday DESC;
  • Birden Fazla Sütuna Göre Sıralama:

    -- Önce soyadına göre artan, aynı soyadına sahip olanları ada göre artan sırala
    SELECT * FROM member ORDER BY last_name ASC, first_name ASC; 

Sonuç Sayısını Sınırlama (LIMIT)

Döndürülecek satır sayısını sınırlamak için LIMIT kullanılır. Genellikle ORDER BY ile birlikte kullanılarak en yüksek/düşük veya en yeni/eski kayıtları almak için kullanılır.

  • İlk N Kaydı Alma:

    -- Eklenen ilk 2 üyeyi getir (ID'ye göre sıralı varsayarsak)
    SELECT * FROM member ORDER BY id ASC LIMIT 2; 
  • Belirli Bir Aralıktaki Kayıtları Alma (LIMIT offset, count): Sayfalama gibi işlemler için kullanılır. offset atlanacak satır sayısını, count ise getirilecek satır sayısını belirtir (ilk satırın offset'i 0'dır).

    -- 3. ve 4. üyeleri getir (2 satır atla, 2 satır getir)
    SELECT * FROM member ORDER BY id ASC LIMIT 2, 2; 

Bu temel SELECT komutları ve yan tümceleri, veritabanlarından bilgi almanın temelini oluşturur. Daha karmaşık sorgular için JOIN, gruplama (GROUP BY), fonksiyonlar gibi ileri konular bulunmaktadır.

PreviousTemel SQL Sorgularına GirişNextmysqldump ile yedekleme

Last updated 1 month ago