Bir çok insan tarafından ÅŸu sözleri duyuyorum; “MySQL’de veritabanı aktarınca karakter problemi çıkıyor.”, “MySQL’de karakter seti problemi var.”
Hayır efendim MySQL’de karakter seti problemi yoktur, MySQL’in huyunu suyunu bilmeyen insan vardır.
MySQL veritabanı çalışmasında iki tane farklı karakter seti kullanır. Bunlardan birincisi veritabanı motoruna (database engine; MyISAM, InnoDB) verilir. İkincil olarak baÄŸlantı karakter setidir ve MySQL Client’a verilir.
Öntanımlı MySQL kurulumlarında (Örneğin; Distro repolarından, cPanel, Plesk, vb. hosting otomasyon yazılımları ile) bağlantı ve veritabanı karakter seti latin1 olarak gelmektedir.
En sık yapılan hatayı şöyle basit bir hatadır. KiÅŸi gider veritabanını UTF-8 olarak yaratır. Sonra PHP ile sadece baÄŸlanır ve sürekli veri yazar fakat bu veriyi yazdıran zat-ı muhterem bu sunucuya baÄŸlantı sırasında MySQL Client’ın kullandığı karakter seti merak etmez. Bunu irdelemediÄŸi için de UTF-8 veritabanına Latin1 ile baÄŸlanır ve verileri böyle yazar. Sonuç! absürt karakterlere sahip bir veritabanı.
Ne yapıyormuşuz demek ki, veritabanını istediğimiz karakter seti ile yaratıyormuşuz, daha sonra bağlanırken de veritabanının sahip olduğu karakter seti ile bağlanıyormuşuz. Evet tam olarak böyle.
Mesela UTF-8 bir veritabanı yarattığımızı varsayalım. Buna bağlanırken kesinlikle şunu yapmıyoruz;
| PHP | | | | ? |
| 1 | |
| 2 | mysql_connect("server","kullanici","sifre"); |
| 3 | mysql_select_db("veritabani"); |
| 4 | mysql_query("insert into tablo ('a','b') values ('ÇÖPĞÖÜĞÜ','İŞÜĞÜMÖMÖM')"); |
| 5 |
Bunun yerine; bağlantıdan hemen sonra bir seferlik;
| PHP | | | | ? |
| 1 | |
| 2 | mysql_connect("server","kullanici","sifre"); |
| 3 | mysql_select_db("veritabani"); |
| 4 | mysql_query("SET NAMES UTF8"); |
| 5 | mysql_query("SET CHARACTER SET UTF8"); |
| 6 | |
| 7 | mysql_query("insert into tablo ('a','b') values ('ÇÖPĞÖÜĞÜ','İŞÜĞÜMÖMÖM')"); |
| 8 |
durumu MySQL’e bildiriyoruz.
Tabi ki bir projede 50 yerde baÄŸlantı kuranlar bu noktada OOP’nin neden varolduÄŸunu anlayabilirler.
- “Ee bilmem ne SQL Server bunu otomatik seçiyormuÅŸ”.
- Peki multi collation olan bu sistemde farklı farklı tablolar için ne yapmayı düşünüyorsun? diye sormazlar mı kişiye.
Önemli olan nasıl yediğin değil, o yoğurdu yemek!