Konular
Link Değişimi
Php
Mysql
Html
Javascript
Windows Vista
Program Anlatımı
Internet
Google
Windows 2003 Server
Komikler
Windows Xp
Isa Server
Network
Ofis Programları
Css
Photoshop
Donanım
Joomla
Youtube Video
Diğer Konular
Jquery

Linklerimiz
Eskişehirde Satılık Daireler
Yacht Charter Turkey
Yachting Turkey
Otel Şikayet
Lara 5 Yıldızlı Otel Fiyatları
Hilton Bodrum Türkbükü Resort & Spa Fiyatları
Günlük Tekne Turu Fiyatları
Rhodes Marmaris Ferry Boat
Used Yacht Sale Turkey
Otel telefon
Otel Video
Otel Dizin
Otel Directory
Otel Resimleri
Otel Maps
Boutique Gulets

 
php MySQL Tablolarının ve Tablo Alanlarının Karakter Setini Topluca Değiştirmek
MySQL veri tabanı kullanıyorsanız karakter seti tanımlamaları yüzünden zaman zaman sıkıntılı anlar yaşamışsınızdır. Aşağıdaki betik sayesinde bu tür sorunlarınızın ufak bir bölümüne çözüm sağlayabilirsiniz. Betiğin yaptığı iş tanımlanan karakter setini tüm tablolara ve tablo içinde alanlara uygulamaktan ibarettir. Performansını test etmesemde, üçyüzden fazla tablonun ve sayısı birkaç bini geçen tablo alanlarının tamamının karakter setinin değiştirilmesi 15-20 saniye civarında sürmüştür.

Örnek1: Kullanmakta olduğunuz tablolarınız utf8 ve tablolarınızın içindeki alanlar utf8_general_ci olarak tanımlanmış olsun. Bu durumda MySQL u ve ü harflerinde sorun çıkaracaktır. Bu sorunu gidermek tüm tabloarı ve tablolardaki alanları utf8_turkish_ci karakter setine geçirmeniz gerekecek. Bu durumda bu betiği kullanabilirsiniz.

Örnek 2: Hazır bir yazılım(wordpress, openads vs.) kurdunuz. Ancak MySQL sunucusunun ön tanımlı karakter seti latin1 olduğu için tüm tablolar ve tablo alanları latin1 karakter setinde tanımlanmış oldu. Yazılımı kullanmaya başlamadan önce istediğiniz karakter setiyle(mesela utf8 yada latin5) çalışabilecek hale getirebilirsiniz.(Tabi yazılımın desteklediğini varsayıyorum).

Örnek 3: Hazır bir yazılım kurdunuz, bir süre kullandınız ve veri girdiniz. Ardından karakter setini değiştirmek istediniz, mesela latin5den utf8e geçmek istediniz. Bu betiği kullanırsanız tüm tablolarınız ve tablolarınızın içindeki alanlar istediğiniz karakter setine geçer ancak tablolardaki veriler bozulur. Bu durumdaysanız bu betiği kullanmayınız.

Örneklerden de anlayabileceğiniz gibi, eğer tablolarınızda veri varsa ana karakter setini bu betik ile değiştirebilirsiniz ancak verilerinizin karakter setini bu betik değiştirmez. Fakat ana karakter setini değiştirmeden, alt karakter setleri arasında geçiş yapacaksanız tabloda veri olup olmaması "büyük ihtimalle"(tek tek test edecek vaktim yok maalesef) sorun çıkarmayacaktır.

Her ihtimale karşı betiği kullanmadan önce yedek alın. Yaptığınız değişikliklerden, başarılı veya başarısız farketmez, haberdar ederseniz diğer kullanıcılara faydanız olabilir. Ben utf8_general_ci olarak ayarlı ve içinde veri olan tabloları sorunsuz şekilde utf8_turkish_ci olarak ayarlayabildim.


/*
yazan : turker
e-mail : turker.biz@gmail.com
version : 0.01
------------
Üstteki bilgilere dokunmadan, istediğiniz gibi kullanabilir, satabilir ve dağıtabilirsiniz.
*/
# karakter seti ayarları
$charset='utf8';
# bağlantı ayarları
$conn=mysql_connect("localhost","root","") or die('nerdesin mysql?');
mysql_select_db("testdb",$conn) or die('taze bitti');
# karakter seti değiştirilecek alan tipleri
$types=array(
'CHAR',
'VARCHAR',
'TINYTEXT',
'TEXT',
'MEDIUMTEXT',
'LONGTEXT',
'TINYBLOB',
'BLOB',
'MEDIUMBLOB',
'LONGBLOB',
'ENUM',
'SET'
);
/*---------------- yeter bu kadar ayar ----------------------- */
# follow the white rabbit
$q1=mysql_query('SHOW TABLES');
while ($r1=mysql_fetch_array($q1)) {
$table=$r1[0];
$sql='ALTER TABLE '.$table.' CONVERT TO CHARACTER SET '.
$charset.' COLLATE '.$charset.'_turkish_ci';
mysql_query($sql);
echo "\n\n
$table tablosunun karakter seti değiştirildi";
$q2=mysql_query('SHOW FIELDS FROM `'.$table.'`');
while ($r2=mysql_fetch_assoc($q2)) {
//print_r($r2);
$field=$r2['Field'];
$type=strtoupper($r2['Type']);
$null=strtoupper($r2['Null']);
$default=strtoupper($r2['Default']);
if (in_array($type,$types)) {
if ($null=='YES') $null='NULL';
else $null='NOT NULL';
if (!empty($default)) $default='DEFAULT '.$default;
$sql='ALTER TABLE `'.$table.'` MODIFY COLUMN `'.$field.'` '.$type.' CHARACTER SET '.
$charset.' COLLATE '.$charset.'_turkish_ci '.$null.' '.$default;
mysql_query($sql);
} // if
} // while
echo "\n
$table tablosu içindeki alanların karakter seti değiştirildi";
} // while
Böyyük Patron Tarafından 23-09-2008 Tarihinde Gönderilmiştir.   Bu Konuyu Yazdır
Kaynak : http://perfectgate.net

 

En Son Eklenenler
İnternet
card recovery
php
ip adresi kontrolü ip validate
php
url adresi kontrolü validate url
php
php mail adresi kontrolü filter_var
php
dosya include error hatasını engellemek
jquery
internet explorer position fixed sorununu jquery ile çözmek
jquery
input alanlara girilen sayıların toplanarak gösterilmesi
MYSQL
aynı satırdaki (row) field değerlerin içinde en büyüğünü (max) bulmak
MYSQL
aynı satırdaki (row) field değerlerin içinde en küçüğünü (min) bulmak
jquery
select kutusunda seçilen option daki attribute özelliğindeki değeri almak
jquery
jquery dizide max ve min işlemeleri array max min
MYSQL
mysql de türkçe kayıtlı alanlarda arama yapmak
php
str_shuffle()
php
sql_regcase()
php
mysql_affected_rows()
php
php Chop
php
php pathinfo
MYSQL
Mysql de trigger
php
eposta adresine ait mx kaydının olup olmadığını kontrol etmek
php
Türkçe karakter destekli array sort
Javascript
Diziler ve Türkçe Karakterleri Sıralama
php
php curl türkçe karakter sorunu çözülmüştür
jquery
jquery mouse sağ tuşu kilitlemek
jquery
jquery tagların value değerini öğrenmek
jquery
jquery multiple selector çoklu element seçimi
jquery
jquery zebra tablolar yapmak iki renkli tablo yapımı
jquery
jquery sayfayı refresh etmek sayfayı yenilemek
jquery
jquery resim yüklenemiyorsa farklı resim göstermek
php
tckimlik sorgulama
php
php ile javascript ve style (css) dosyalarını browsere sıkıştırarak göndermek
php
curl ile twitpic.com sitesine resim upload etmek
php
stringde aradağımız stringin posizyonunu bulmak tripos()
php
stringdeki karakekterlerden rastgele yeni karakter türetmek str_shuffle()
php
addcslashes()
php
sabitleri yoketmek defined()
php
php kodlarını renkli göstermenin basit yolu show_source()
php
glob ile dosya listelemek
php
iki ayrı dizide değeri aynı olanlardan yeni bir dizi yapmak array_intersect()
php
dizi key ile değerini yer değiştirmek array_flip()
php
dizilere filtre uygulamak array filter
İletişim : bpatron@codekodu.com
774703Kişi Tarafından Sitemiz Ziyaret Edilmiştir. 12 Kişi Online
Bugün 01 Saat 55 Dakikada Sitemizi Tekil 72 Kişi Ziyaret Etmiştir.
Dün Sitemizi Tekil 740 Kişi Ziyaret Etmiştir.
Sitemizi En Çok Tekil 12-12-2011 Tarihinde 857 Kişi Ziyaret Etmiştir.
Sitemizdeki bilgilerin büyük çoğunluğu alıntıdır.İlgili yazının yazarının veya kaynak sahibinin istemesi halinde ilgili yazı sitemizden kaldırılacaktır.
Sitemizin İmalatı Böyyükpatron Tarafından Yapılmıştır.