Php+mysql tabanlı site tasarımları hazırlayan yeni arkadaşların en büyük problemleridir, mysql 4 üzerindeki karakter problemleri. Aslında göründüğü kadar zor birşeyde değildir düzeltmesi. Hem phpnuke hem wordpress kurarken olsun, karşılaştığım en büyük problemdi bu. Bu sadece mysql 4 üzerinde oluşan birşey. Yani mysql 4′ler üstünde karakter kodlama seçenekleri söz konusu.
Yeni bir veritabanı yarattığınızda, Karşılaştırma(Collation) değerinin latin1_general_ci, latin1_swedish_ci v.b. olduğunu göreceksiniz. Siz bu veritabanı üstüne tablolarınızı yaratır ve kullanıma hazır hale getirirsiniz. Fakat her tablo için varsayılan karşılaştırma değeri, yine veritabanında kullanılan değer olacaktır.
Aslında karşılaştırma değeri, tabloların dil kodlamasıdır. Ve sadece metin içerikli sütunlarda görünmektedir. Bunun anlamı, o sütunda seçmiş olduğunuz dilin kullanılacağı diyebilirim. Standart olarak swedish geçer. Sizlerin bu sütunlara yollayacağınız kayıtlar ise, isveçce dili göz önünde bulundurularak girilir. Bundan da şu çıkar: isveçcede Türkçe karakter yer almaz, bu yüzden Türkçe karakterler yerine ? v.b. karakter bulacaksınız. Sanırım genel olarak anlatabildim bu kısmı.
Yeni bir veritabanı yaratırken, karşılaştırma değerini daima latin5_turkish_ci seçin. Dilimize ait karakter kodu budur. Bu şekilde veritabanını yaratırsanız, tablolar için yapmanız gereken fazladan birşey yok. Tablo yaratırken, metin değerli sütunların karşılaştırma değerlerini boş bırakabilir yada yine latin5_turkish_ci seçebilirsiniz.
Sıra php kodlarınızı yazmaya geldiğinde, tabi ki tablonuzun karşılaştırma değerini sql dilinde belirtmelisiniz. Bunun için aşağıda vereceğim kodu kullanacaksınız. Bunu veritabanı bağlantısı kurup, ilgili veritabanını seçtiğiniz satırın bir alt satırana girebilirsiniz.
mysql_query("SET NAMES 'latin5'");
Bu kodumuz tüm sorgularda, karşılaştırma değerinin latin5 olacağını söyler. Böylelikte gireceğiniz Türkçe karakterler sorunsuz şekilde tablolara yazılacaktır.
Mysql 4 üstünde Türkçe karakter hatasını bu şekilde çözebilirsiniz. Ayrıca benzeri uygumalayı, hazır içerik yönetim kodlamaları üstüne de uygulayabilirsiniz. Tek mantık burasıdır
Bu yazı 25 Ekim 2005, 08:32 tarihinde yazılmış olup bu zamana kadar 47,299 kez görüntülenmiştir
En son ise 28 Eylül 2008, 16:22 tarihinde güncellenmiştir
Bu yazı 204 adet yorum almıştır ve bunların son 10 adeti görüntülenmektedir. Bu yazıya yapılan tüm yorumları görmek için arşivi görüntüleyiniz. TÜM YORUMLARI OKUMAK İÇİN TIKLAYINIZ.
Merhaba yazmış olduğunuz bilgiler gerçekten çok güzel. Benim çözemediğim bir problemim var.Denedim ama olmadı. Site üzerinde türkçe karakterlerle yapılan aramalarda hiç bir sonuç çıkmıyor. İngilizce yapılınca sonuçlar gözüküyor.
Örnek : magazin diye aranınca çıkıyor MAGAZİN diye aranınca çıkmıyor.
yardımcı olursanız çok sevinirim
tesekkur ederim.
Bu ufak kodla karşılaştığım sorunu çözmüş oldun. Çok teşekkürler.
Bir kayıp olmaz Furkan, çünkü bütün gelişmiş portal yazılımlarında bu sorgu öncelikli olarak yapılıyor artık ![]()
Merhaba, bu önemli bilgi için teşekkürler. yaşadığım sorunu sayenizde aştım. fakat bir sorum olacak. bunu kullanırsam eğer 20k tekil hitli bir sitede performans nasıl olur ? yani performans kaybı ne derece olur ?
kolay gelsin
Bazen bu işe yaramayabiliyor. Böyle durumlarda htmlspecialchars fonksiyonunu kullanabilirsiniz.
<?php
$new = htmlspecialchars(”Test“, ENT_QUOTES);
echo $new; //
ahmet alp tşk ![]()
uygulama tarafı için connection string içine
stmt=SET NAMES ‘Latin5′
eklerseniz bu iş olur
örnek
——————–
“DRIVER={MySQL ODBC 3.51 Driver};SERVER=localhost;DATABASE=test;UID=root;PASSWORD=123456;OPTION=3;stmt=SET NAMES ‘Latin5′”
tablolardan birisini utf-8turkish ci yaptım türkçe karakteri destekleddi
ama diğer tablolarıma yaptığımda nedense türkçe karakteri desteklemiyor ![]()
Sorununa Yanıt Bulamayan Arkadaşlar Phpmyadminde Elle Girerseniz Veri Çekerken Türkçe Karaterlerin Bozuk Çıkması Doğal Eğer Veri leri Web Arabirimi Kullanarak Veri tabanına İşlerseniz Bu sorun Ortadan Kalkıcaktır..Çünkü Web ara birimi Kullanırken Türkçe karakleri Dönüştürürek Kayıt Yapıyor…Ve Çekerkende Türkçe Karateri Orjinali olarak Gönderiyor…Veya Veri tabanına PhpMyadmin giricekseniz Türkçe Karaterlerin Karşılığını yazmalısınız..
Büyük İhtimal Sorununa Yanıt Bulamayanların Cevabı Budur…
Yazını çok beğendim. Yeni yazılarının e-posta adresime gelmesini istiyorum :)