SQLite - Genel Bakış
Bu bölüm, SQLite'ın ne olduğunu, SQL'den nasıl farklı olduğunu, neden gerekli olduğunu ve Veritabanı uygulamalarını işleme şeklini anlamanıza yardımcı olur.
SQLite, kendi kendine yeten, sunucusuz, sıfır konfigürasyonlu, işlemsel SQL veritabanı motorunu uygulayan bir yazılım kitaplığıdır. SQLite, etraftaki en hızlı büyüyen veritabanı motorlarından biridir, ancak bu, boyutuyla ilgili bir şey değil, popülerlik açısından büyüme. SQLite için kaynak kodu kamu malıdır.
SQLite nedir?
SQLite, kendi kendine yeten, sunucusuz, sıfır konfigürasyonlu, işlemsel bir SQL veritabanı motoru uygulayan bir işlem içi kitaplıktır. Sıfır yapılandırılmış bir veritabanıdır, yani diğer veritabanları gibi sisteminizde yapılandırmanıza gerek yoktur.
SQLite motoru, diğer veritabanları gibi bağımsız bir işlem değildir, uygulamanıza ihtiyacınıza göre onu statik veya dinamik olarak bağlayabilirsiniz. SQLite, depolama dosyalarına doğrudan erişir.
Neden SQLite?
SQLite, çalışması için ayrı bir sunucu işlemi veya sistem gerektirmez (sunucusuz).
SQLite sıfır konfigürasyonla gelir, bu da kurulum veya yönetime gerek olmadığı anlamına gelir.
Tam bir SQLite veritabanı, tek bir çapraz platform disk dosyasında saklanır.
SQLite çok küçük ve hafiftir, tam olarak yapılandırılmış 400KiB'den az veya isteğe bağlı özellikler atlanmış 250KiB'den azdır.
SQLite bağımsızdır, bu da harici bağımlılık olmadığı anlamına gelir.
SQLite işlemleri tamamen ACID uyumludur ve birden çok işlemden veya iş parçacığından güvenli erişim sağlar.
SQLite, SQL92 (SQL2) standardında bulunan sorgu dili özelliklerinin çoğunu destekler.
SQLite, ANSI-C ile yazılmıştır ve basit ve kullanımı kolay API sağlar.
SQLite, UNIX (Linux, Mac OS-X, Android, iOS) ve Windows (Win32, WinCE, WinRT) üzerinde mevcuttur.
SQLite Kısa Bir Tarihçe
2000 - D. Richard Hipp, bir programı çalıştırmak için herhangi bir yönetim gerektirmemek amacıyla SQLite'ı tasarladı.
2000 - Ağustos'ta SQLite 1.0, GNU Veritabanı Yöneticisi ile birlikte yayınlandı.
2011 - Hipp, SQLite DB'ye UNQl arayüzü ekleyeceğini ve UNQLite (Belge odaklı veritabanı) geliştireceğini duyurdu.
SQLite Sınırlamaları
Aşağıdaki tabloda listelenen SQLite'da SQL92'nin birkaç desteklenmeyen özelliği vardır.
Sr.No. | Özellik Açıklama |
---|---|
1 | RIGHT OUTER JOIN Yalnızca LEFT OUTER JOIN uygulanır. |
2 | FULL OUTER JOIN Yalnızca LEFT OUTER JOIN uygulanır. |
3 | ALTER TABLE ALTER TABLE komutunun RENAME TABLE ve ADD COLUMN varyantları desteklenir. DROP COLUMN, ALTER COLUMN, ADD CONSTRAINT desteklenmez. |
4 | Trigger support FOR EACH ROW tetikleyicileri desteklenir ancak FOR EACH STATEMENT tetikleyicileri desteklenmez. |
5 | VIEWs SQLite'daki GÖRÜNÜMLER salt okunurdur. Bir görünümde DELETE, INSERT veya UPDATE deyimi yürütemezsiniz. |
6 | GRANT and REVOKE Uygulanabilecek tek erişim izinleri, temeldeki işletim sisteminin normal dosya erişim izinleridir. |
SQLite Komutları
İlişkisel veritabanları ile etkileşim için standart SQLite komutları SQL'e benzer. Bunlar CREATE, SELECT, INSERT, UPDATE, DELETE ve DROP'tur. Bu komutlar, operasyonel yapılarına göre gruplara ayrılabilir -
DDL - Veri Tanımlama Dili
Sr.No. | Komut ve Açıklama |
---|---|
1 | CREATE Veritabanında yeni bir tablo, bir tablo görünümü veya başka bir nesne oluşturur. |
2 | ALTER Tablo gibi var olan bir veritabanı nesnesini değiştirir. |
3 | DROP Tüm tabloyu, bir tablonun görünümünü veya veritabanındaki başka bir nesneyi siler. |
DML - Veri Manipülasyon Dili
Sr.No. | Komut ve Açıklama |
---|---|
1 | INSERT Bir kayıt oluşturur |
2 | UPDATE Kayıtları değiştirir |
3 | DELETE Kayıtları siler |
DQL - Veri Sorgulama Dili
Sr.No. | Komut ve Açıklama |
---|---|
1 | SELECT Bir veya daha fazla tablodan belirli kayıtları alır |