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 相关文章推荐
mysql From_unixtime及UNIX_TIMESTAMP及DATE_FORMAT日期函数
Mar 21 PHP
第4章 数据处理-php数组的处理-郑阿奇
Jul 04 PHP
PHP命名空间(Namespace)简明教程
Jun 11 PHP
2014最热门的24个php类库汇总
Dec 18 PHP
php自动获取关键字的方法
Jan 06 PHP
php计算两个坐标(经度,纬度)之间距离的方法
Apr 17 PHP
Yii2中添加全局函数的方法分析
May 04 PHP
php将html转为图片的实现方法
May 19 PHP
PHP中的函数声明与使用详解
May 27 PHP
PHP弱类型语言中类型判断操作实例详解
Aug 10 PHP
PHP高并发和大流量解决方案整理
Dec 24 PHP
阿里云服务器搭建Php+Apache运行环境的详细过程
May 15 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)
2010/09/04 PHP
php自动加载autoload机制示例分享
2014/02/20 PHP
CodeIgniter连贯操作的底层原理分析
2016/05/17 PHP
php实现带读写分离功能的MySQL类完整实例
2016/07/28 PHP
CodeIgniter框架基本增删改查操作示例
2017/03/23 PHP
php+iframe 实现上传文件功能示例
2020/03/04 PHP
ThinkPHP 框架实现的读取excel导入数据库操作示例
2020/04/14 PHP
json 实例详细说明教程
2009/10/31 Javascript
JS仿Windows开机启动Loading进度条的方法
2015/02/26 Javascript
JavaScript让网页出现渐隐渐显背景颜色的方法
2015/04/21 Javascript
常用jQuery代码分享
2015/07/14 Javascript
JSON简介以及用法汇总
2016/02/21 Javascript
JavaScript订单操作小程序完整版
2017/06/23 Javascript
vue.js实现单选框、复选框和下拉框示例
2017/07/18 Javascript
Vue表单demo v-model双向绑定问题
2018/06/29 Javascript
jQuery+Datatables实现表格批量删除功能【推荐】
2018/10/24 jQuery
NodeJs实现简单的爬虫功能案例分析
2018/12/05 NodeJs
VuePress 静态网站生成方法步骤
2019/02/14 Javascript
微信小程序如何访问公众号文章
2019/07/08 Javascript
VUE项目中加载已保存的笔记实例方法
2019/09/14 Javascript
js实现星星海特效的示例
2020/09/28 Javascript
Linux下将Python的Django项目部署到Apache服务器
2015/12/24 Python
Django框架的使用教程路由请求响应的方法
2018/07/03 Python
Python标准库itertools的使用方法
2020/01/17 Python
python机器学习库xgboost的使用
2020/01/20 Python
python:HDF和CSV存储优劣对比分析
2020/06/08 Python
CSS3 transition 实现通知消息轮播条
2020/10/14 HTML / CSS
canvas中普通动效与粒子动效的实现代码示例
2019/01/03 HTML / CSS
美国名牌手表折扣网站:Jomashop
2020/05/22 全球购物
银行学习十八大感想
2014/01/11 职场文书
机关党建工作汇报材料
2014/08/20 职场文书
大学生档案自我鉴定(2篇)
2014/10/14 职场文书
2016年元旦寄语
2015/08/17 职场文书
《伯牙绝弦》教学反思
2016/02/16 职场文书
Python中OpenCV实现查找轮廓的实例
2021/06/08 Python
Vue自定义铃声提示音组件的实现
2022/01/22 Vue.js