# Python PostgreSQL Veritabanı
Python PostgreSQL veritabanı işlemlerini öğreniyoruz.
PostgreSQL; güçlü, açık kaynak kodlu, nesne ilişkisel ve tüm işletim sistemlerinde çalışabilen gelişmiş bir veritabanı sistemidir. SQL diliyle birlikte kullanılan PostgreSQL’in verileri güvenli bir şekilde saklama, karmaşık verileri ölçeklendirme, hız, performans gibi bir çok özelliği ve avantajı vardır. PostgreSQL hakkında daha detaylı bilgileri araştırma yaparak öğrenebilirsiniz. Bu yazımızda ise Python ile PostgreSQL kullanımını anlatmaya odaklanacağız.
1. Psycopg2
Kütüphanesinin Kurulması ve Projeye Dahil Etme
Psycopg2
Kütüphanesinin Kurulması ve Projeye Dahil EtmePython ve PostgreSQL veritabanı bağlantısı işlemini yapabilmek için birçok modül mevcuttur. Biz bunların arasında daha yaygın bir kullanıma sahip olan Psycopg2
kütüphanesini kullanacağız. Maddelere dökersek ise Psycopg2
kütüphanesi kullanmamızın sebepleri arasında başlıca şunlar vardır;
Psycopg2, PostgreSQL için en popüler python modülüdür.
Birçok Python ve Postgres frameworku ile hali hazırda kullanılan kütüphanedir.
Python 3 ve Python 2 sürümleri ile sorunsuz çalışır
Özet bilgilerden sonra ilk işimiz Psycopg2
modülünü kurmak olsun.
Artık kütüphanemizi kurduğumuza göre projemize kütüphaneyi dahil edebiliriz. Bunu yapabilmek için dosyamızın en üstüne aşağıdaki kodu ekleyelim:
Kütüphaneyi indirip projemize dahil ettikten sonra artık örneklerimize başlayabiliriz.
2. PostgreSQL Veritabanı Bağlantısı
Artık veritabanımıza bağlantımızı yapacak bilgileri oluşturmanın zamanı geldi. Bunun için aşağıdaki kod blogunu ekleyerek kullanıcı adı, şifre ve veritabanı adını kendinize göre düzenlemelisiniz:
3. İmleç Oluşturma
Veritabanı bağlantısı ile komutlarımızı gönderebilmek için aracı bir imleç oluşturmamız gerekiyor. İmleç oluşturmak için aşağıdaki kodları kullanabilirsiniz.
Buraya kadar olan işlemlerin doğruluğunu test etmek için aşağıdaki komut ile bağlantı bilgilerimizi ekrana yazdıralım.
Ekran çıktımız aşağıdaki gibi olmalıdır.
Python ile PostgreSQL veritabanı bağlantısını başarıyla yaptıktan sonra artık işlemlerimize geçebiliriz.
4. CREATE İle Tablo Oluşturma İşlemi
Temel işlemlerden başladığımıza göre ilk olarak üzerinde çalışabileceğimiz basit bir tablo oluşturalım ve bu tablonun adını isimler
olarak belirleyelim. Tablomuzun yapısı ve bu tabloyu oluşturacak CREATE
komutu şu şekilde olacaktır.
SÜTUN ADI | TİP | ÖZELLİKLER |
id | integer | Primary Key, Auto Increment |
ad | text | Not NULL |
soyad | text | Not NULL |
Burada SQL komutumuzu yazdıktan sonra execute()
fonksiyonu ile çalıştırıyoruz ve değişikliklerin veritabanı üzerinde de yapılması için commit()
fonksiyonu ile işlemi tamamlıyoruz.
Tablomuz hazır, temel işlemlere başlayabiliriz.
5. INSERT İle Tabloya Veri Ekleme İşlemi
Oluşturduğumuz isimler
tablosuna diğer başlıklarda kullanmak üzere birkaç örnek veri ekleyelim. Bunun için INSERT
komutunu kullanıyoruz.
Bu şekilde birkaç satır ekleyelim ve tablomuzu kontrol edelim.
6. SELECT İle Tablodan Verileri Alma İşlemi
En çok kullanılan komut olan SELECT
ile devam edelim. Bunun için örnek olarak oluşturduğumuz isimler
tablosunu çekerek ekrana yazdıralım:
Bu komut ile ekran çıktımız şu şekilde olacaktır.
fetchall()
fonksiyonu ile execute()
fonksiyonu sayesinde işlediğimiz SQL komutunun çıktısını bir diziye atmış olduk. Bu diziyi de for döngüsü ile ekrana yazdırdık. Dönen dizide sütun isimlerine göre yazdırma işlemi yapmak istiyorsak ta aşağıdaki komutu kullanabiliriz.
Ekran çıktımız ise şu şekilde olacaktır.
NOT: Sorgu sonucunda tüm satırları çekmek için fetchall()
, tüm satırlar yerine tek satır almak istiyorsanız fetchone()
, belirli sayıda satır çekmek istiyorsanız da fetchmany(SIZE)
fonksiyonunu kullanabilirsiniz.
7. UPDATE İle Veri Güncelleme İşlemi
Şimdi geldik tablomuzdaki mevcut bir değeri güncellemeye. Bu işlem için UPDATE
komutunu kullanacağız. Aşağıdaki örneği hemen incelemeye başlayabilirsiniz:
id
sütun değeri 1 olan hücrede ki "Furkan" değerini "Abdullah" ile değiştirdiğimiz komut sonucu tablomuz şu şekilde olacaktır.
8. DELETE İle Veri Silme İşlemi
Tablomuzdan bir değer silmek istersek DELETE
komutunu kullanabiliriz. Hemen örneğimizi görelim.
Ardından tablomuzun yeni hali şu şekilde olacaktır.
9. SONUÇ
Bu yazımızda Python ile PostreSQL veritabanı bağlantısını ve temel işlemleri nasıl yapabileceğimizi öğrendik. Bunu yaparken de işin temelinin SQL komutlarımızı sorunsuz bir şekilde hazırlayıp execute()
fonksiyonuyla bağlantısını tamamladığımız veritabanımıza göndermek olduğunu ve ardından işlemlerin veritabanı kısmında da gerçekleşmesi için commit()
ettiğimizi gördünüz. Sizde daha gelişmiş işlerinizde yukarıdaki örnekleri baz alabilir, takıldığınız yerleri aşağıya yorum bırakarak sorabilirsiniz.
Last updated