ThinkPHP5.1 按照汉字的拼音排序

3 篇文章 0 订阅

参考文章:http://www.bubuko.com/infodetail-3261995.html

1、通过网上查询资料,可总结出:

(1)如果存储姓名的字段采用的是GBK字符集,那就好办了,因为GBK内码编码时本身就采用了拼音排序的方法(常用一级汉字3755个采用拼音排序,二级汉字就不是了,但考虑到人名等都是常用汉字,因此只是针对一级汉字能正确排序也够用了),直接在查询语句后面 添加 order by name asc; 查询结果按照姓氏的升序排序;

(2)如果存储姓名的字段采用的是 UTF8字符集,需要在排序的时候对字段进行转码;对应的代码是 order by convert(name using gbk) asc; 同样,查询的结果也是按照姓氏的升序排序;

我相信大多数人用的应该是用的UTF8字符集,所以这里就使用第二种方法

2、具体操作

使用TP中的一个类Expression(use think\db\Expression;)来实现,示例代码如下:

use think\db\Expression;

//按店铺名称排序则让列表中的店铺按照店铺名称(shop_name)拼音首字母排序
$exp = new Expression('convert(shop_name using gbk) asc');

$shop_list = $this->sM->where($where)
         ->limit($start, $size)
         ->field('...,shop_name,...')
         ->orderRaw($exp)
         ->select();

注意:当你的order排序中使用了SQL函数的时候,请使用orderRaw方法替代order

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值