MySQL 汉字转拼音
2018-08-20 18:24
369 查看
以前一直写脚本将数据库中的中文转成拼音首字母保存,突然发现原来mysql也有这个功能,特意备份下!
fristPinyin : 此函数是将一个中文字符串的第一个汉字转成拼音字母 (例如:"中国人"->Z)
pinyin :此函数是将一个中文字符串对应拼音母的每个相连 (例如:"中国人"->ZGR)
示例:
如果在创建函数的时候出现如下错误:
This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its de...
这是我们开启了bin-log, 我们就必须指定我们的函数是否是
1 DETERMINISTIC 不确定的
2 NO SQL 没有SQl语句,当然也不会修改数据
3 READS SQL DATA 只是读取数据,当然也不会修改数据
4 MODIFIES SQL DATA 要修改数据
5 CONTAINS SQL 包含了SQL语句
其中在function里面,只有 DETERMINISTIC, NO SQL 和 READS SQL DATA 被支持。如果我们开启了 bin-log, 我们就必须为我们的function指定一个参数。
在MySQL中创建函数时出现这种错误的解决方法:
set global log_bin_trust_function_creators=TRUE;
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
示例:
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
如果在创建函数的时候出现如下错误:
This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its de...
这是我们开启了bin-log, 我们就必须指定我们的函数是否是
1 DETERMINISTIC 不确定的
2 NO SQL 没有SQl语句,当然也不会修改数据
3 READS SQL DATA 只是读取数据,当然也不会修改数据
4 MODIFIES SQL DATA 要修改数据
5 CONTAINS SQL 包含了SQL语句
其中在function里面,只有 DETERMINISTIC, NO SQL 和 READS SQL DATA 被支持。如果我们开启了 bin-log, 我们就必须为我们的function指定一个参数。
在MySQL中创建函数时出现这种错误的解决方法:
set global log_bin_trust_function_creators=TRUE;
相关文章推荐
- MySQL按照汉字的拼音排序
- MySQL按照汉字的拼音排序简单实例
- MySQL按照汉字拼音首字母排序
- mysql获取汉字拼音
- mysql 存储过程 汉字取拼音或者首字母
- MySQL按照汉字的拼音排序(A-Z)
- mysql 查询汉字的全拼音以及查询各个汉字的拼音首字母
- MySQL汉字字段按拼音排序
- MySQL按照汉字的拼音排序
- mysql汉字拼音取法
- MySQL按照汉字的拼音排序
- mysql 查询汉字的全拼音以及查询各个汉字的拼音首字母
- MySQL按照汉字的拼音排序
- Mysql中文汉字转拼音的实现(每个汉字转换全拼)
- MySQL下使用SQL按照汉字拼音排序
- MySQL中文汉字转拼音的自定义函数和使用实例(首字的首字母)
- php/Mysql汉字按拼音首字母检索
- Mysql中文汉字转拼音的实现(每个汉字转换全拼)
- MySQL按照汉字的拼音排序(转)
- MSSQL 获取汉字的首拼音 MYSQL 获取汉字的首拼音