项目中有时候需要按照汉字的拼音排序,比如联系人列表、矿物分类等,有的还需要按拼音字母从A到Z分类显示。

  如果存储汉字的字段编码使用的是GBK字符集,因为GBK内码编码时本身就采用了拼音排序的方法(常用一级汉字3755个采用拼音排序,二级汉字就不是了,但考虑到人名等都是常用汉字,因此只是针对一级汉字能正确排序也够用了),直接在查询语句后面添加ORDER BY name ASC,查询结果将按照姓氏的升序排序;如果存储姓名的字段采用的是utf8字符集,需要在排序的时候对字段进行转码,对应的代码是ORDER BY convert(name using gbk) ASC,同样,查询的结果也是按照姓氏的升序排序。

  按拼音首字母分类显示的时候,需要借助一个中间表,存储的是字母对应的汉字的编码范围,这样的话,每次取出汉字然后跟中间表比对就可以了,中间表创建和插入数据的SQL如下:

/*
Navicat MySQL Data Transfer Target Server Type : MYSQL
Target Server Version : 50617
File Encoding : 65001 Date: 2015-07-02 11:12:15
*/ SET FOREIGN_KEY_CHECKS=0; -- ----------------------------
-- Table structure for t_coslers
-- ----------------------------
DROP TABLE IF EXISTS `t_coslers`;
CREATE TABLE `t_coslers` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`f_PY` char(1) CHARACTER SET utf8 DEFAULT NULL,
`cBegin` smallint(5) unsigned NOT NULL,
`cEnd` smallint(5) unsigned NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=24 DEFAULT CHARSET=latin1; -- ----------------------------
-- Records of t_coslers
-- ----------------------------
INSERT INTO `t_coslers` VALUES ('1', 'A', '45217', '45252');
INSERT INTO `t_coslers` VALUES ('2', 'B', '45253', '45760');
INSERT INTO `t_coslers` VALUES ('3', 'C', '45761', '46317');
INSERT INTO `t_coslers` VALUES ('4', 'D', '46318', '46825');
INSERT INTO `t_coslers` VALUES ('5', 'E', '46826', '47009');
INSERT INTO `t_coslers` VALUES ('6', 'F', '47010', '47296');
INSERT INTO `t_coslers` VALUES ('7', 'G', '47297', '47613');
INSERT INTO `t_coslers` VALUES ('8', 'H', '47614', '48118');
INSERT INTO `t_coslers` VALUES ('9', 'J', '48119', '49061');
INSERT INTO `t_coslers` VALUES ('10', 'K', '49062', '49323');
INSERT INTO `t_coslers` VALUES ('11', 'L', '49324', '49895');
INSERT INTO `t_coslers` VALUES ('12', 'M', '49896', '50370');
INSERT INTO `t_coslers` VALUES ('13', 'N', '50371', '50613');
INSERT INTO `t_coslers` VALUES ('14', 'O', '50614', '50621');
INSERT INTO `t_coslers` VALUES ('15', 'P', '50622', '50905');
INSERT INTO `t_coslers` VALUES ('16', 'Q', '50906', '51386');
INSERT INTO `t_coslers` VALUES ('17', 'R', '51387', '51445');
INSERT INTO `t_coslers` VALUES ('18', 'S', '51446', '52217');
INSERT INTO `t_coslers` VALUES ('19', 'T', '52218', '52697');
INSERT INTO `t_coslers` VALUES ('20', 'W', '52698', '52979');
INSERT INTO `t_coslers` VALUES ('21', 'X', '52980', '53640');
INSERT INTO `t_coslers` VALUES ('22', 'Y', '53689', '54480');
INSERT INTO `t_coslers` VALUES ('23', 'Z', '54481', '55289');

  借助中间表查询汉字首字母的示例SQL如下(utf8字符集):

SELECT t1.id, t1.name, t2.f_PY
FROM t_user t1, t_coslers t2
WHERE CONV(HEX(LEFT(CONVERT(t1.name USING gbk ), 1)), 16, 10) BETWEEN t2.cBegin AND t2.cEnd
ORDER BY convert(t1.name using gbk) ASC

  需要注意的一点是,上述的排序、分类方法对多音字的支持并不是很好,要求高精度的同学慎用。

MySQL按照汉字的拼音排序、按照首字母分类的更多相关文章

  1. SQL汉字转拼音函数-支持首字母、全拼

    SQL汉字转拼音函数-支持首字母.全拼 FROM :http://my.oschina.net/ind/blog/191659 作者不详 --方法一sqlserver汉字转拼音首字母 --调用方法 s ...

  2. MySQL按照汉字的拼音排序

    按照汉字的拼音排序,用的比较多是在人名的排序中,按照姓氏的拼音字母,从A到Z排序: 如果存储姓名的字段采用的是GBK字符集,那就好办了,因为GBK内码编码时本身就采用了拼音排序的方法(常用一级汉字37 ...

  3. MySQL按照汉字的拼音排序,mysql汉字排序

    按照汉字的拼音排序,用的比较多是在人名的排序中,按照姓氏的拼音字母,从A到Z排序: 如果存储姓名的字段采用的是GBK字符集,那就好办了,因为GBK内码编码时本身就采用了拼音排序的方法(常用一级汉字37 ...

  4. MySQL按照汉字的拼音排序(转)

    按照汉字的拼音排序,用的比较多是在人名的排序中,按照姓氏的拼音字母,从A到Z排序: 如果存储姓名的字段采用的是GBK字符集,那就好办了,因为GBK内码编码时本身就采用了拼音排序的方法(常用一级汉字37 ...

  5. java汉字转拼音以及得到首字母通用方法

    package oa.common.utils;   import net.sourceforge.pinyin4j.PinyinHelper; import net.sourceforge.piny ...

  6. vue集成汉字转拼音或提取首字母

    需求:             有时我们为了节省用户的维护量,需要根据中文生成出相应的拼音和缩写 解决:            此方法是利用汉字和Unicode编码对应找到相应字母 一.编写汉字和编码 ...

  7. 使用PHP获取汉字的拼音(全部与首字母)

    <?php /** * 取汉字拼音 * edit by www.jbxue.com */ class GetPingYing { private $pylist = array( 'a'=> ...

  8. JAVA汉字转拼音(取首字母大写)

    import net.sourceforge.pinyin4j.PinyinHelper;import net.sourceforge.pinyin4j.format.HanyuPinyinCaseT ...

  9. [转]Java汉字按照拼音排序

    最近项目上使用到汉字排序的问题,网上搜索了一下后普遍使用下面的方法比较. @Test public void test_sort_pinyin() { Collator cmp = Collator. ...

随机推荐

  1. 改动app的默认设置(包含改动默认launcher)

    1.改为自己的launcher ComponentName component = new ComponentName( context.getPackageName(), MainActivity. ...

  2. css语法和JS语法的对比

      CSS语法(不区分大小写) JavaScript语法(区分大小写) border border border-bottom borderBottom border-bottom-color bor ...

  3. 示例 Demo 工程和 API 参考链接

    Camera Explorer:有关 Windows Phone8 中有关增强 Camera API 的使用.文章链接 Filter Effects:对拍摄的照片或者图片库中的照片应用 Nokia I ...

  4. JAVA-Word转PDF各种版本实现方式

    当下做一个项目,就是各种操作office,客户的需求总是各种不按常理,来需求就得搞啊.对JAVA操作office这方面真是头大,弟弟是真滴不懂不会啊.无奈只好试啊试的.网上一大堆好使的,一大堆不好使的 ...

  5. Photoshop学习笔记(1)--界面设置

    根据慕课网教学视频整理(抄了一个妹子的评论): http://www.imooc.com/video/9813 ps版本:CS6 步骤: 1.视图->显示->智能参考线,以及视图-> ...

  6. Python中import和from import

    Python里面的import和from import都是用于导入一个模块,两者的区别是 如果你在使用某模块内函数时不想写模块名,那么就用from import方式导入,如果是用import方式就要写 ...

  7. [Eth]网络查看命令:route

    最近在调试网络,出现问题,两个网口分别接外网内网,结果不同 http://www.cnblogs.com/peida/archive/2013/03/05/2943698.html

  8. java线程池的应用浅析

    import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.FileReader; import java ...

  9. GDI+学习笔记

    7.1.1 GDI+概述 GDI+是微软在Windows 2000以后操作系统中提供的新的图形设备接口,其通过一套部署为托管代码的类来展现, 这套类被称为GDI+的“托管类接口”,GDI+主要提供了以 ...

  10. java 多线程 2 Thread中start()和run()的区别