Rumah > Artikel > pembangunan bahagian belakang > Bagaimana untuk menyelesaikan masalah aksara yang kacau apabila php membaca data dari pangkalan data
Apabila menulis tapak web atau aplikasi menggunakan PHP, kadangkala aksara bercelaru muncul apabila membaca data daripada pangkalan data. Ini adalah masalah yang sangat biasa, tetapi ia sangat menjengkelkan. Dalam artikel ini, kami akan meneroka punca data bercelaru apabila membaca data daripada pangkalan data dalam PHP dan cara membetulkannya.
Punca aksara bercelaru
Pindahkan data antara aplikasi dan pangkalan data Jika mereka menggunakan set aksara yang berbeza, data akan bercelaru. Contohnya, jika pangkalan data menggunakan set aksara UTF-8 dan aplikasi menggunakan set aksara ISO-8859-1, data yang diperoleh daripada pangkalan data akan menjadi kacau bilau.
Jika set aksara sambungan pangkalan data tidak ditetapkan, set aksara pelayan akan digunakan secara lalai. Jika set aksara pelayan tidak konsisten dengan set aksara pangkalan data, aksara bercelaru akan muncul semasa penghantaran data.
Kadangkala, data yang disimpan dalam pangkalan data mungkin terdiri daripada set aksara bercampur, seperti pengekodan UTF-8 dan GBK dalam medan yang sama watak. Dalam kes ini, aksara bercelaru akan muncul apabila membaca data.
Penyelesaian
Dalam MySQL, anda boleh menukar set aksara pangkalan data menggunakan arahan berikut:
ALTER DATABASE database_name DEFAULT CHARACTER SET utf8;
Untuk aplikasi, anda boleh menetapkan set aksara kepada UTF-8 dalam PHP menggunakan arahan berikut :
mysqli_set_charset($link, "utf8");
Dalam MySQL, anda boleh menetapkan set aksara apabila menyambung ke pangkalan data:
$link = mysqli_connect("localhost", "user", "password", "dbname"); mysqli_set_charset($link, "utf8");
Data dalam MySQL boleh ditukar kepada UTF-8 menggunakan arahan berikut:
ALTER TABLE table_name CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;
Sebagai alternatif, teks boleh ditukar kepada UTF-8 dalam PHP menggunakan kod berikut:
$data = mb_convert_encoding($data, "UTF-8", "auto");
Kesimpulan
Untuk masalah data bercelaru yang dibaca oleh PHP dari pangkalan data, mungkin set aksara tidak konsisten semasa penghantaran data, pangkalan data set aksara sambungan tidak ditetapkan, atau Set aksara dalam pangkalan data mengelirukan. Untuk mengelakkan masalah ini, anda boleh menetapkan pangkalan data dan aplikasi kepada set aksara yang sama, dan menetapkan set aksara apabila menyambung ke pangkalan data. Jika aksara bercelaru masih muncul, anda boleh cuba membersihkan data dalam pangkalan data dan menukar semuanya kepada UTF-8.
Atas ialah kandungan terperinci Bagaimana untuk menyelesaikan masalah aksara yang kacau apabila php membaca data dari pangkalan data. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!