永发信息网

mysql 自定义函数 如何传入中文参数

答案:2  悬赏:10  手机版
解决时间 2021-01-12 23:17
  • 提问者网友:欲望失宠
  • 2021-01-12 04:33
mysql 自定义函数 如何传入中文参数
最佳答案
  • 五星知识达人网友:荒野風
  • 2021-01-12 05:36
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
全部回答
  • 1楼网友:蓝房子
  • 2021-01-12 06:07
中文看做字符串处理传入即可。
比如创建hello函数,传入'你好'
mysql> CREATE FUNCTION hello (s CHAr(20))
mysql> RETURNS CHAr(50) DETERMINISTIC
-> RETURN CONCAt('Hello, ',s,'!');
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT hello('你好');
+----------------+
| hello('world') |
+----------------+
| 你好! |
+----------------+
1 row in set (0.00 sec)
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯