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 相关文章推荐
Memcache 在PHP中的使用技巧
Feb 08 PHP
php 对输入信息的进行安全过滤的函数代码
Jun 29 PHP
浅谈php serialize()与unserialize()的用法
Jun 05 PHP
探讨GDFONTPATH能否被winxp下的php支持
Jun 21 PHP
一个不易被发现的PHP后门代码解析
Jul 05 PHP
10款实用的PHP开源工具
Oct 23 PHP
php实现阳历阴历互转的方法
Oct 28 PHP
php对二维数组进行相关操作(排序、转换、去空白等)
Nov 04 PHP
PHP模板引擎Smarty之配置文件在模板变量中的使用方法示例
Apr 11 PHP
php_pdo 预处理语句详解
Nov 21 PHP
php对微信支付回调处理的方法
Aug 23 PHP
ThinkPHP5.1表单令牌Token失效问题的解决
Mar 22 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过滤危险html代码
2008/08/18 PHP
解决php接收shell返回的结果中文乱码问题
2014/01/23 PHP
PHP+MYSQL实现用户的增删改查
2015/03/24 PHP
9个比较实用的php代码片段
2016/03/15 PHP
JQUERY 对象与DOM对象之两者相互间的转换
2009/04/27 Javascript
document.getElementById为空或不是对象的解决方法
2010/01/24 Javascript
EASYUI TREEGRID异步加载数据实现方法
2012/08/22 Javascript
jquery1.10给新增元素绑定事件的方法
2014/03/06 Javascript
node.js中的fs.fsyncSync方法使用说明
2014/12/15 Javascript
jQuery获取页面及个元素高度、宽度的总结——超实用
2015/07/28 Javascript
原生JS取代一些JQuery方法的简单实现
2016/09/20 Javascript
javascript 动态样式添加的简单实现
2016/10/11 Javascript
原生js实现吸顶效果
2017/03/13 Javascript
WebStorm ES6 语法支持设置&babel使用及自动编译(详解)
2017/09/08 Javascript
vue.js实现带日期星期的数字时钟功能示例
2018/08/28 Javascript
如何使用Node.js爬取任意网页资源并输出PDF文件到本地
2019/06/17 Javascript
JavaScript实现省份城市的三级联动
2020/02/11 Javascript
基于JavaScript或jQuery实现网站夜间/高亮模式
2020/05/30 jQuery
Python操作Sql Server 2008数据库的方法详解
2018/05/17 Python
python跳过第一行快速读取文件内容的实例
2018/07/12 Python
Python3爬虫学习之应对网站反爬虫机制的方法分析
2018/12/12 Python
python调用外部程序的实操步骤
2019/03/04 Python
python实现控制台输出彩色字体
2020/04/05 Python
Python基于yaml文件配置logging日志过程解析
2020/06/23 Python
解决keras,val_categorical_accuracy:,0.0000e+00问题
2020/07/02 Python
使用Python制作一盏 3D 花灯喜迎元宵佳节
2021/02/26 Python
美国奢侈品购物平台:Orchard Mile
2018/05/02 全球购物
英国索普公园票务和酒店套餐:Thorpe Breaks
2019/09/14 全球购物
Oasis服装官网:时尚女装在线
2020/07/09 全球购物
合同专员岗位职责
2013/12/18 职场文书
人力资源主管岗位职责
2014/01/29 职场文书
毕业班联欢会主持词
2014/03/27 职场文书
护士长竞聘演讲稿
2014/04/30 职场文书
小学生常见病防治方案
2014/06/06 职场文书
企业战略合作意向书
2015/05/08 职场文书
详解Go语言中配置文件使用与日志配置
2022/06/01 Golang