MYSQL 中英文排序,中文根据拼音排序

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MYSQL 中英文排序,中文根据拼音排序相关的知识,希望对你有一定的参考价值。

SELECT * FROM `name` ORDER BY name
如何同时将中文根据拼音首字母进行排序
参考网站:http://my.oschina.net/u/999578/blog/150392
已解决:
SELECT name
FROM `table_name`
ORDER BY CONVERT( name
USING gbk )
COLLATE gbk_chinese_ci ASC

参考技术A 有个不成熟的方法 你可以再加一列 存拼音 专门用于排序

按拼音首字母排序

<?php
                $temp = array();
                // 按拼音首字母排序
                foreach($res as $key=>$val){
                    $index = $this->sortByPinyin($val[note_name]);
                    $temp[$index][] = $val; //先用中间变量数组,根据字母A B C..装着集合在一起的   
                }
                $list = array();
                foreach($temp as $k=>$v){
                    $list[$k][index] = $k;
                    $list[$k][list] = $v;
                }
                array_multisort($list); //用 array_multisort按键排序,也可用 ksort()
                // ksort($list);
                $list = array_values($list); //最后将键弄回数字的那些键 , A, B ,C ... => 0, 1, 2....

    /**
     * [获取字符串的拼音首字母]
     * @param  [type] $str [description]
     * @return [type]      [description]
     */
    public function sortByPinyin($str)
    {
      if(empty($str)){
         return ‘‘;
      }
      $fchar = ord($str{0});
      if($fchar>=ord(A)&&$fchar<=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;
    }

最后的结果是:(下面是json的形式)

[
  {
    "index": "A",
    "list": [
      {
        "id": "6",
        "suid": "1",
        "note_name": "哎去"
      },
      {
        "id": "7",
        "suid": "1",
        "note_name": "abf"
      }
    ]
  },
  {
    "index": "B",
    "list": [
      {
        "id": "9",
        "suid": "1",
        "note_name": "标签2"
      }
    ]
  },
  {
    "index": "C",
    "list": [
      {
        "id": "1",
        "suid": "1",
        "note_name": "测试"
      }
    ]
  },
  {
    "index": "D",
    "list": [
      {
        "id": "3",
        "suid": "1",
        "note_name": "DSA"
      }
    ]
  }
]

 

以上是关于MYSQL 中英文排序,中文根据拼音排序的主要内容,如果未能解决你的问题,请参考以下文章

mysql根据汉字首字母排序的方法并按字母分组

MySQL实现中文拼音排序

java+mysql,关于根据拼音首字母查询

mysql 按中文拼音字母排序

MySQL中文排序

mysql 汉字按拼音字母排序获取拼音首字母拼音全拼