永发信息网

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

答案:2  悬赏:10  手机版
解决时间 2021-01-12 23:17
mysql 自定义函数 如何传入中文参数
最佳答案
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
全部回答
中文看做字符串处理传入即可。
比如创建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)
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
上午9点开始上课 授业は午前9时からです 为
蓄深而流长蕴含的哲理
有人打电话来又要想着加害我们?
java如何把txt文件转换成xml文件
捡到天然玉石归谁所有权
求使命召唤1~14
植物大战僵尸 水池无限 小僵尸吃玉米炮问题
付六分之五除以负三分之2×负二分之3=多少有
柳州科目四补考要多少钱
女士有哪些类型的服饰?
女孩,我对她说明我的意思,我爱上她,她却说
车享网半价购车经历
玫瑰精油的好坏怎么分辨?
玩上单杰斯需要带传送么
烤过的红翡还是a货吗
推荐资讯
在那个节日里 八年级作文
为什么人家搬家要早晨早一点
德州什么车床最好
电子科大有mpacc么
1000一1一91
东西18米南北21米临街老地基东边有4米的巷子
吃樱奢胶原蛋白多肽片有什么注意事项吗?
大于或等于符号是什么样子的?
青岛瑞丽服饰有限公司
怎么压脚背?
滚瓜烂熟的熟字是什么意思
婚戒刻字,想在戒指上分别刻上体谅和包容两个
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?