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ı.

Çözüm Yolu
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.

[code]PLAIN TEXTmysql_query("SET NAMES 'latin5'"); [/code]

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 uygulamayı, hazır içerik yönetim kodlamaları üstüne de uygulayabilirsiniz.

Beğeniler: 0
Favoriler: 0
İzlenmeler: 4121
favori
like
share
kartal_67 Tarih: 15.05.2009 16:10
sağol işime yaradi
MAVi Tarih: 28.04.2009 20:20
türkçeyi katledecekler en sonunda....
By_ergen Tarih: 08.12.2007 10:19
eLLerine saglık arkadasım
fiber_optic Tarih: 23.02.2007 12:36
Sql Server 2005 için

Merhaba;

Tablo : ID , Ad , Soyad alanlarından oluşsun.

Excelde de :

ID Ad Soyad

1 Hasan Mansur
2 Figen Çınkır
3 Sem Göksu

olsun.SQL Server da ilfgili database de sağ tıklayarak import dediğimizde, kaynak olarak bu exceli gösterelim.Sonrada hedef olarak bu database i .Sonrada Query ile aktarmayı seçerek query olarak :



SELECT *

FROM `Sheet1$`

SQL_Latin1_General_Cp1254_CS_AS


yazarsan türkçe karakterlerde insert edilir.
FreddyKrueger Tarih: 07.02.2007 21:05
BiLqiLer Için Te$ekkürLer...


tek1088 Tarih: 27.01.2007 09:58
babacan ben dediklerini uygulayamadım peki bunu pbpbb ye nasıl uyarlıycaz yani onda neler yapacaz anlatırsan çok iyi olacak

kardeş ben halletim sağol