参考文章: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