PostgreSQL Türkçe Karakter Hatasının Çözümleri

Merhaba,
Yaklaşık olarak 7-8 yıldan bu yana MySQL veri tabanı kullanıyorum. MySQL’den PostgreSQL’e geçmeyi hep istiyordum fakat erteleye erteleye bu kadar zaman geçmiş demek ki!

PostgreSQL hakkında uzunca araştırmalardan sonra yeni bir projede kullanmaya karar verdim. Database oluşturup, tabloları create etmeye başladım. Her şey çok güzel gidiyordu 🙂

Ta ki “LIKE” operatörü ile türkçe küçük i veya büyük İ araması yaptığımda sonuçların gelmediğini farkettim. Sonra PostgreSQL’de “ILIKE” operatörü olduğunu farkettim. Fakat bu operatörde problemi çözmemişti. Stackoverflow üzerinde çözümü aramaya başladım. Birçok kişinin bu durumdan muzdarip olduğunu fakat bir sonuca ulaşamadıklarını farkettim. Yada ben bulamadım 🙁 PostgreSQL’de acemi olduğum için sağlıklı bir sonuca da ulaşamadım açıkçası.

Daha sonra twitter üzerinden DM ile M.Atıf Ceylan‘a konunun detaylarını anlattım. Sağolsun, zaman ayırıp bunun neden kaynaklandığını hakkında cevap yazdı.

Bu durumun collate ile alakalı olduğunu, veritabanı oluştururken “tr_TR.utf-8” tanımlamasını yaptığımda sorunun ortadan kalkacağını belirtti.

Ben de veritabanını dışarı aktarıp mevcut veritabanını sildim. Daha sonraki adımları aşağıda belirtiyorum.

Database oluşturma esnasında aşağıdaki gibi LC_COLLATE için tr_TR.UTF-8 değerini belirtiyoruz.

Yine aynı şekilde tablo oluşturma esnasında aşağıdaki gibi COLLATE için tr_TR.UTF-8 değerini belirtiyoruz.

PostgreSQL’in kullandığınız versiyona göre seçebileceğiniz collation ları aşağıdaki sorgu ile bulabilirsiniz.

Yukarıdaki sorguda tr_TR.UTF-8 tanımlı değilse aşağıdaki komutları çalışırın.

Daha sonra aşağıdaki SQL’i çalıştırıyoruz. Çalıştırdıktan sonra listelendiğini göreceksiniz.

Artık türkçe karakter problemi yaşamadan PostgreSQL nimetlerinden faydalanmaya başlayabiliriz 🙂

Son olarak desteği için M.Atıf Ceylan‘a teşekkür ederim.

Bu sayfa 2.246 kez görüntülendi.

Ahmet

Sıradan bloglardan birisi :) Google+

Bunlar da hoşunuza gidebilir...

5 Cevaplar

  1. Mehmet Saygılı dedi ki:

    Merhaba, malesef bu çözüm docker üzerinde koşan debian yada ubuntu üzerindeki bir postgresql veri tabanı için geçerli değil. 🙁 Yazınızı ilk okurken çok sevinmiştim problemi çözen birisi var diye ama tekrar hüsran 🙁

    Docker üzerinde hiç deneme fırsatı buldunuz mu? debian ya da alpine linux üzerinde.

  2. Berkay AKÇAY dedi ki:

    Merhaba,

    locale listesine ekleme yaptıktan sonra postgresql’i yeniden başlatmak gerekebiliyor.

    **
    service –status-all
    service postgresql status
    service postgresql restart
    **

  3. hüseyin berber dedi ki:

    Merhaba, psql v12 kullanıyorum. Lc_locate ve c_type ayarını yaptım db’de fakat arama yaparken i ve ı harflerinde büyük küçük problemi var hala örnek verecek olursam ILIKE kullanıyorum İ diye aratınca İSTANBUl’u buluyor kümük i yapınca maalesef bulamıyorum

  4. Ahmet dedi ki:

    Hüseyin Merhaba,
    Mevcut veritabanını silip, aşağıdaki syntax ile tekrar oluşturur musun?
    LC_CTYPE parametresi ile de dener misin?

    CREATE DATABASE test_db ENCODING='UTF-8' LC_COLLATE = 'tr_TR.UTF-8' LC_CTYPE='tr_TR.UTF-8' TEMPLATE template0;

Bir cevap yazın

E-posta hesabınız yayımlanmayacak. Gerekli alanlar * ile işaretlenmişlerdir

Yorum onaylama sistemi etkin; yorumunuzun yayınlanması biraz zaman alabilir.