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 相关文章推荐
怎么样可以把 phpinfo()屏蔽掉?
Nov 24 PHP
php中处理模拟rewrite 效果
Dec 09 PHP
可以在线执行PHP代码包装修正版
Mar 15 PHP
解析ajax事件的调用顺序
Jun 17 PHP
浅析PHP原理之变量(Variables inside PHP)
Aug 09 PHP
php学习笔记之基础知识
Nov 08 PHP
PHP实现的简单三角形、矩形周长面积计算器分享
Nov 18 PHP
Yii框架在页面输出执行sql语句以方便调试的实现方法
Dec 24 PHP
php 微信开发获取用户信息如何实现
Dec 13 PHP
PHP实现通过文本文件统计页面访问量功能示例
Feb 13 PHP
Discuz不使用插件实现简单的打赏功能
Mar 21 PHP
PHP 数组黑名单/白名单实例代码详解
Jun 04 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
?繁体转换的class
2006/10/09 PHP
PHP 批量删除数据的方法分析
2009/10/30 PHP
PHP 引用是个坏习惯
2010/03/12 PHP
PHP基于DateTime类解决Unix时间戳与日期互转问题【针对1970年前及2038年后时间戳】
2018/06/13 PHP
探讨javascript是不是面向对象的语言
2013/11/21 Javascript
JavaScript实现图片滑动切换的代码示例分享
2016/03/06 Javascript
jQuery简单实现列表隐藏和显示效果示例
2016/09/12 Javascript
js转html实体的方法
2016/09/27 Javascript
JavaScript prototype属性详解
2016/10/25 Javascript
jQuery实现两个select控件的互移操作
2016/12/22 Javascript
利用Node.js对文件进行重命名
2017/03/12 Javascript
AngularJS中$http使用的简单介绍
2017/03/17 Javascript
一个有意思的鼠标点击文字特效jquery代码
2017/09/23 jQuery
Vue中this.$router.push参数获取方法
2018/02/27 Javascript
浅谈VUE单页应用首屏加载速度优化方案
2018/08/28 Javascript
简单说说angular.json文件的使用
2018/10/29 Javascript
Electron 如何调用本地模块的方法
2019/02/01 Javascript
Vue源码之关于vm.$delete()/Vue.use()内部原理详解
2019/05/01 Javascript
jsonp格式前端发送和后台接受写法的代码详解
2019/11/07 Javascript
Angular单元测试之事件触发的实现
2020/01/20 Javascript
python脚本内运行linux命令的方法
2015/07/02 Python
python 对类的成员函数开启线程的方法
2019/01/22 Python
浅析Python 读取图像文件的性能对比
2019/03/07 Python
Python3使用Matplotlib 绘制精美的数学函数图形
2019/04/11 Python
python读取当前目录下的CSV文件数据
2020/03/11 Python
python实时监控logstash日志代码
2020/04/27 Python
基于python连接oracle导并出数据文件
2020/04/28 Python
Expedia丹麦:全球领先的旅游网站
2018/03/18 全球购物
Foot Locker德国官方网站:美国运动服和鞋类零售商
2018/11/01 全球购物
荷兰在线钓鱼商店:Raven
2019/06/26 全球购物
人力资源部培训专员岗位职责
2014/01/02 职场文书
工作室成员个人发展规划范文
2014/01/24 职场文书
社会体育专业大学生职业生涯规划书
2014/09/17 职场文书
班子四风对照检查材料思想汇报
2014/09/29 职场文书
2014年学生会主席工作总结
2014/11/07 职场文书
2015年社区关工委工作总结
2015/04/03 职场文书