一、PHP+MySQL出现中文乱码的原因。
1. MYSQL数据库的编码是utf8,与PHP网页的编码格式不一致,就会造成MYSQL中的中文乱码。
2. 使用MYSQL中创建表、或者选择字段时设置的类型不是utf8,而网页编码不是utf8,也可能造成MYSQL中文乱码.
3. PHP页面的字符集与数据库的编码不一致。
4. PHP连接MYSQL数据库, *** 作是设定的语句指定的编码和页面编码,PHP页面编码不一致。
5. 用户提交的HTML页面编码,和显示数据的页面编码不一致 ,就肯定会造成PHP页面乱码.
二、解决中文乱码:
1. 网页编码设置。一般在HTML代码中的文件头<html>中加入属性:
<meta http-equiv=”Content-Type” content=”text/htmlcharset=utf-8″>
保证,网页是"utf-8"编码。
2. PHP代码设置。在php代码的开始部分加入以下代码:
header(”Content-type: text/htmlcharset=utf-8″)
且要求保存的文件编码方式是utf-8,这样就保证了该文件也是utf-8编码。
3. 数据库中表的字段中存储中文的部分,要设置为utf8_general_ci类型。
4.PHP在连接数据库 *** 作时,要设置 *** 作的字段类型为utf8,设置方法如下:
mysql_connect(’localhost’,'user’,'password’)mysql_select_db(’db’)mysql_query(”set names utf8”)//**设置字符集***
首先 在网上 找找函数 把中文转换成拼音的例如 to_pinyin()
然后
$data_sort = array()
foreach($data as $row){
$data[to_pinyin($row)] = $row
}
最后 用 键值排序 就可以了
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)