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