PHP与MYSQL中UTF8 中文排序示例代码


Posted in PHP onOctober 23, 2014

1. 需要在php数组中用中文排序,但是一般使用utf8格式的文件,直接用asort排序不行。用gbk和gb2312可以。这跟几种格式的编码有关系。gbk和gb2312本身的编码就是用拼音排序的。

代码如下

function utf8_array_asort(&$array)
{
if(!isset($array) || !is_array($array))
{
return false;
}
foreach($array as $k=>$v)
{
$array[$k] = iconv('UTF-8', 'GBK//IGNORE',$v);
}
asort($array);
foreach($array as $k=>$v)
{
$array[$k] = iconv('GBK', 'UTF-8//IGNORE', $v);
}
return true;
}

2. 在MySQL中,我们经常会对一个字段进行排序查询,但进行中文排序和查找的时候,对汉字的排序和查找结果往往都是错误的。 这种情况在MySQL的(3water.com)很多版本中都存在。
如果这个问题不解决,那么MySQL将无法实际处理中文。 出现这个问题的原因是因为MySQL在查询字符串时是大小写不敏感的,在编绎MySQL时一般以ISO-8859字符集作为默认的字符集,因此在比较过程中中文编码字符大小写转换造成了这种现象。
解决方法:
对于包含中文的字段加上"binary"属性,使之作为二进制比较,例如将"name char(10)"改成"name char(10)binary"。
如果你使用源码编译MySQL,可以编译MySQL时使用 --with--charset=gbk 参数,这样MySQL就会直接支持中文查找和排序了(默认的是latin1)。也可以用 extra-charsets=gb2312,gbk 来加入多个字符集。
如果不想对表结构进行修改或者重新编译MySQL,也可以在查询语句的 order by 部分使用 CONVERT 函数。比如

代码如下

select * from mytable order by CONVERT(chineseColumnName USING gbk);
PHP 相关文章推荐
php 结果集的分页实现代码
Mar 10 PHP
PHP中遍历stdclass object的实现代码
Jun 09 PHP
php防止SQL注入详解及防范
Nov 12 PHP
织梦sitemap地图实时推送给百度的教程
Aug 03 PHP
CodeIgniter自定义控制器MY_Controller用法分析
Jan 20 PHP
CodeIgniter 完美解决URL含有中文字符串
May 13 PHP
图文详解phpstorm配置Xdebug进行调试PHP教程
Jun 13 PHP
浅谈Yii乐观锁的使用及原理
Jul 25 PHP
Laravel学习教程之从入口到输出过程详解
Aug 27 PHP
PHP聊天室简单实现方法详解
Dec 08 PHP
php设计模式之观察者模式定义与用法经典示例
Sep 19 PHP
使用php的mail()函数实现发送邮件功能
Jun 03 PHP
php cookie名使用点号(句号)会被转换
Oct 23 #PHP
php格式化时间戳显示友好的时间实现思路及代码
Oct 23 #PHP
PHP正则表达式 /i, /is, /s, /isU等介绍
Oct 23 #PHP
PHP函数实现分页含文本分页和数字分页
Oct 23 #PHP
10个实用的PHP正则表达式汇总
Oct 23 #PHP
PHP中怎样防止SQL注入分析
Oct 23 #PHP
PDO防注入原理分析以及使用PDO的注意事项总结
Oct 23 #PHP
You might like
php中DOMDocument简单用法示例代码(XML创建、添加、删除、修改)
2010/12/19 PHP
PHP中文分词 自动获取关键词介绍
2012/11/13 PHP
php绘图之加载外部图片的方法
2015/01/24 PHP
JavaScript prototype属性深入介绍
2012/11/27 Javascript
Jquery chosen动态设置值实例介绍
2013/08/08 Javascript
javascript 小数取整简单实现方式
2014/05/30 Javascript
JavaScript不刷新实现浏览器的前进后退功能
2014/11/05 Javascript
jQuery中removeData()方法用法实例
2014/12/27 Javascript
Javascript基础之数组的使用
2016/05/13 Javascript
浅谈js中的三种继承方式及其优缺点
2016/08/10 Javascript
js闭包用法实例详解
2016/12/13 Javascript
Bootstrap基本模板的使用和理解1
2016/12/14 Javascript
Vue中使用vux的配置详解
2017/05/05 Javascript
Bootstrap弹出框之自定义悬停框标题、内容和样式示例代码
2017/07/11 Javascript
angular $watch 一个变量的变化(实例讲解)
2017/08/02 Javascript
vue 使用Jade模板写html,stylus写css的方法
2018/02/23 Javascript
Vue 项目中遇到的跨域问题及解决方法(后台php)
2018/03/28 Javascript
解决vue2 在mounted函数无法获取prop中的变量问题
2018/11/15 Javascript
python基于socket实现网络广播的方法
2015/04/29 Python
利用python实现命令行有道词典的方法示例
2017/01/31 Python
详谈Python中列表list,元祖tuple和numpy中的array区别
2018/04/18 Python
python数据处理 根据颜色对图片进行分类的方法
2018/12/08 Python
jupyter lab的目录调整及设置默认浏览器为chrome的方法
2020/04/10 Python
基于matplotlib中ion()和ioff()的使用详解
2020/06/16 Python
Python高阶函数与装饰器函数的深入讲解
2020/11/10 Python
HTML5 Notification(桌面提醒)功能使用实例
2014/03/17 HTML / CSS
RentCars.com巴西:汽车租赁网站
2016/08/22 全球购物
英国内衣连锁店:Boux Avenue
2018/01/24 全球购物
会计电算化专业自荐信
2014/03/15 职场文书
员工薪酬激励方案
2014/06/13 职场文书
职称评定个人总结
2015/03/05 职场文书
安全生产奖惩制度
2015/08/06 职场文书
Pytorch 实现变量类型转换
2021/05/17 Python
分享五个Node.js开发的优秀实践 
2022/04/07 NodeJs
Python实现视频自动打码的示例代码
2022/04/08 Python
css让页脚保持在底部位置的四种方案
2022/07/23 HTML / CSS