mysql数据库,获取某一个汉字的拼音的首字母。怎么整?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql数据库,获取某一个汉字的拼音的首字母。怎么整?相关的知识,希望对你有一定的参考价值。

网上给出的我都试了。不好用啊。是我的问题还是怎么搞得?

参考技术A 首先建立一个汉字字库,将拼音及首字母存入库中,然后通过创建的检索函数进行快速读取。

php获取汉字拼音首字母的方法

现实中我们经常看到这样的说明,排名不分先后,按姓名首字母进行排序。这是中国人大多数使用的排序方法。那么在php程序中该如何操作呢?

 

下面就分享一下在php程序中获取汉字拼音的首字母的方法,在网上搜到的大多数是有问题的,这个可是经过小编实践应用过的,真的可以使用的哦。

//php获取中文字符拼音首字母
function getFirstCharter($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;
}

举例如下:

1
echo getFirstCharter(‘脚本之家www.jb51.net‘);//结果将输出:J

 

以上是关于mysql数据库,获取某一个汉字的拼音的首字母。怎么整?的主要内容,如果未能解决你的问题,请参考以下文章

SqlServer 获取汉字的拼音首字母

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

php获取汉字拼音首字母的方法

SQL 获取名字拼音

文本域输入汉字 第二个文本域立即显示汉字的获取首个字母 如何用JS实现

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