欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MySQL中文汉字转拼音的自定义函数和使用实例(首字的首字母)

程序员文章站 2024-02-29 21:56:10
fristpinyin : 此函数是将一个中文字符串的第一个汉字转成拼音字母 (例如:"中国人"->z)复制代码 代码如下:create function `fris...

fristpinyin : 此函数是将一个中文字符串的第一个汉字转成拼音字母 (例如:"中国人"->z)

复制代码 代码如下:

create function `fristpinyin`(p_name varchar(255)) returns varchar(255) charset utf8
begin
    declare v_return varchar(255);
    set v_return = elt(interval(conv(hex(left(convert(p_name using gbk),1)),16,10),
        0xb0a1,0xb0c5,0xb2c1,0xb4ee,0xb6ea,0xb7a2,0xb8c1,0xb9fe,0xbbf7,
        0xbfa6,0xc0ac,0xc2e8,0xc4c3,0xc5b6,0xc5be,0xc6da,0xc8bb,
        0xc8f6,0xcbfa,0xcdda,0xcef4,0xd1b9,0xd4d1),   
    'a','b','c','d','e','f','g','h','j','k','l','m','n','o','p','q','r','s','t','w','x','y','z');
    return v_return;
end

pinyin :此函数是将一个中文字符串对应拼音母的每个相连 (例如:"中国人"->zgr)
复制代码 代码如下:

create function `pinyin`(p_name varchar(255)) returns varchar(255) charset utf8
begin
    declare v_compare varchar(255);
    declare v_return varchar(255);
    declare i int;

    set i = 1;
    set v_return = '';
    while i < length(p_name) do
        set v_compare = substr(p_name, i, 1);
        if (v_compare != '') then
            #set v_return = concat(v_return, ',', v_compare);
            set v_return = concat(v_return, fristpinyin(v_compare));
            #set v_return = fristpinyin(v_compare);
        end if;
        set i = i + 1;
    end while;

    if (isnull(v_return) or v_return = '') then
        set v_return = p_name;
    end if;

    return v_return;
end


示例:
复制代码 代码如下:

mysql> select p.province, fristpinyin(p.province), pinyin(p.province) from province p;
+------------------+-------------------------+--------------------+
| province         | fristpinyin(p.province) | pinyin(p.province) |
+------------------+-------------------------+--------------------+
| 北京市           | b                       | bjs                |
| 天津市           | t                       | tjs                |
| 河北省           | h                       | hbs                |
| 山西省           | s                       | sxs                |
| 内蒙古自治区     | n                       | nmgzzq             |
+------------------+-------------------------+--------------------+
5 rows in set