# Veritabanı

Veritabanları, yapılandırılmış bilgileri (verileri) depolamak, yönetmek, sorgulamak ve güncellemek için kullanılan organize sistemlerdir. Modern uygulamaların ve web sitelerinin temel taşlarından biridir.

## Neden Veritabanı Kullanılır?

* **Veri Kalıcılığı:** Uygulama kapansa veya sistem yeniden başlasa bile verilerin saklanmasını sağlar.
* **Veri Bütünlüğü:** Belirlenen kurallar (kısıtlamalar, veri tipleri) aracılığıyla verinin doğruluğunu ve tutarlılığını korur.
* **Verimli Erişim:** Büyük miktarda veri içinden istenen bilgiye hızlı ve verimli bir şekilde erişmek için indeksleme ve sorgulama mekanizmaları sunar.
* **Eşzamanlılık Kontrolü:** Birden fazla kullanıcının veya uygulamanın aynı anda veritabanına güvenli bir şekilde erişmesini ve değişiklik yapmasını yönetir.
* **Güvenlik:** Kullanıcı yetkilendirme ve erişim kontrolü mekanizmaları ile verilere kimin erişebileceğini ve hangi işlemleri yapabileceğini sınırlar.
* **Yedekleme ve Kurtarma:** Veri kaybına karşı yedekleme ve kurtarma mekanizmaları sunar.

## Veritabanı Türleri

Birçok farklı veritabanı modeli bulunmaktadır, ancak en yaygın olanlardan bazıları şunlardır:

* **İlişkisel Veritabanları (Relational Databases - RDBMS):** Verileri satırlar ve sütunlardan oluşan tablolarda saklar. Tablolar arasında ilişkiler kurulabilir. SQL (Structured Query Language) sorgulama dili kullanılır. En yaygın kullanılan türdür. Örnekler: MySQL, MariaDB, PostgreSQL, SQLite, Oracle Database, Microsoft SQL Server.
* **NoSQL Veritabanları:** İlişkisel modelin kısıtlamalarına alternatif olarak geliştirilmişlerdir. Farklı veri modelleri kullanırlar:
  * **Belge Tabanlı (Document):** Verileri JSON/BSON benzeri belgelerde saklar (örn. MongoDB, Couchbase).
  * **Anahtar-Değer (Key-Value):** Basit anahtar-değer çiftleri olarak saklar (örn. Redis, Memcached).
  * **Sütun Ailesi (Column-Family):** Büyük veri setleri için optimize edilmiştir (örn. Cassandra, HBase).
  * **Grafik (Graph):** Veriler arasındaki ilişkileri ön plana çıkarır (örn. Neo4j, ArangoDB).

## İlişkisel Veritabanı Nedir?

İlişkisel veritabanları, verileri önceden tanımlanmış bir şemaya göre yapılandırılmış tablolarda saklar.

* **Tablolar (Tables):** Belirli bir türdeki verileri tutar (örn. 'kullanicilar', 'urunler', 'siparisler').
* **Satırlar (Rows/Records):** Tablodaki her bir kaydı temsil eder (örn. belirli bir kullanıcı, belirli bir ürün).
* **Sütunlar (Columns/Fields/Attributes):** Bir kaydın belirli bir özelliğini temsil eder (örn. 'kullanici\_adi', 'email', 'urun\_fiyati'). Her sütunun belirli bir veri tipi vardır (örn. INTEGER, VARCHAR, DATE).
* **Anahtarlar (Keys):**
  * **Birincil Anahtar (Primary Key):** Tablodaki her satırı benzersiz şekilde tanımlayan bir veya daha fazla sütun.
  * **Yabancı Anahtar (Foreign Key):** Bir tablodaki sütunun, başka bir tablonun birincil anahtarına başvurarak tablolar arasında ilişki kurmasını sağlar.
* **SQL (Structured Query Language):** İlişkisel veritabanlarında veri tanımlamak (CREATE TABLE), veri işlemek (INSERT, UPDATE, DELETE) ve veri sorgulamak (SELECT) için kullanılan standart dildir.

Bu kitapta, Linux ortamında yaygın olarak kullanılan ilişkisel veritabanlarından **MySQL** (ve onun topluluk tarafından geliştirilen popüler bir çatalı olan **MariaDB**) üzerine odaklanılacaktır. Ayrıca, güçlü ve açık kaynaklı bir alternatif olan **PostgreSQL** de sıklıkla tercih edilen bir seçenektir.

* [MySQL / MariaDB](/veritabani/mysql.md)


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://linux-yonetimi.veriteknik.net.tr/veritabani.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
