数据库 按照昵称排序

本文介绍了如何在数据库中根据昵称进行排序,探讨了相关的SQL查询语句和优化方法,适用于需要对用户昵称进行字母或拼音排序的场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<?php
/**
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2019/3/20
 * Time: 15:34
 */

namespace App\CustomSystemConfig;


class MailList
{

    /**
     * 将数组按字母A-Z排序
     * @return [type] [description]
     */
    public static function chartSort($list,$filed){

        foreach ($list as $k => &$v) {
            $v['chart'] = self::getFirstChart( $v[$filed] );
        }

        $data=[];

        foreach ($list as $k=>$value){

            if ( empty( $data[ $value['chart'] ] ) ) {

                $data[ $value['chart'] ]=[];
            }
            $data[ $value['chart'] ][]=$value;
        }

        ksort($data);
        return $data;
    }

    /**
     * 将数组按字母A-Z排序
     * @return [type] [description]
     */
    public static function chartSortJson($list,$filed){

        foreach ($list as $k => &$v) {
            $v['chart'] = self::getFirstChart( $v[$filed] );
        }

        $data=[];
        foreach ($list as $k => $v) {
            if ( empty( $data[ $v['chart'] ] ) ) {
                $data[ $v['chart'] ]=[];
            }
            $data[ $v['chart'] ][]=$v;
        }
        ksort($data);
        return $data;
    }

    /**
     * 返回取汉字的第一个字的首字母
     * @param  [type] $str [string]
     * @return [type]      [strind]
     */
    public static function getFirstChart($str){

        if( empty($str) ){
            return '';
        }

        $char=ord($str[0]);

        if( $char >= ord('A') && $char <= ord('z') ){
            return strtoupper($str[0]);
        }

        $s1=iconv('UTF-8','gb2312',$str);
        $s2=iconv('gb2312','UTF-8',$s1);
        $s=$s2==$str?$s1:$str;
        $asc=ord($s{0})*256+ord($s{1})-65536;
        if($asc>=-20319&&$asc<=-20284) return 'A';
        if($asc>=-20283&&$asc<=-19776) return 'B';
        if($asc>=-19775&&$asc<=-19219) return 'C';
        if($asc>=-19218&&$asc<=-18711) return 'D';
        if($asc>=-18710&&$asc<=-18527) return 'E';
        if($asc>=-18526&&$asc<=-18240) return 'F';
        if($asc>=-18239&&$asc<=-17923) return 'G';
        if($asc>=-17922&&$asc<=-17418) return 'H';
        if($asc>=-17417&&$asc<=-16475) return 'J';
        if($asc>=-16474&&$asc<=-16213) return 'K';
        if($asc>=-16212&&$asc<=-15641) return 'L';
        if($asc>=-15640&&$asc<=-15166) return 'M';
        if($asc>=-15165&&$asc<=-14923) return 'N';
        if($asc>=-14922&&$asc<=-14915) return 'O';
        if($asc>=-14914&&$asc<=-14631) return 'P';
        if($asc>=-14630&&$asc<=-14150) return 'Q';
        if($asc>=-14149&&$asc<=-14091) return 'R';
        if($asc>=-14090&&$asc<=-13319) return 'S';
        if($asc>=-13318&&$asc<=-12839) return 'T';
        if($asc>=-12838&&$asc<=-12557) return 'W';
        if($asc>=-12556&&$asc<=-11848) return 'X';
        if($asc>=-11847&&$asc<=-11056) return 'Y';
        if($asc>=-11055&&$asc<=-10247) return 'Z';
        return null;
    }

    /* 按照前端要求排序*/
    public static function MailJson($list)
    {
        $arr = [];

        foreach ($list as $key=>$value){

            if(empty($arr[$key])){
                $arr[$key]['key'] = $key;
                $arr[$key]['data'] = $value;
            }

            $arr[$key]['data'] = $value;
        }

        return array_values($arr);

    }

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值