zoukankan      html  css  js  c++  java
  • 读取数据库汉字首字母

    加入数据库函数

    查询单个首字母

    CREATE DEFINER=`root`@`localhost` 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;

    查询所有汉字首字母

    CREATE DEFINER=`root`@`localhost` 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 a.goodsName 药品名,fristPinyin(a.goodsName)'单个首字母',pinyin(a.goodsName) '首字母' from jh_goods a

    如果是多音字就呵呵了

  • 相关阅读:
    PCA本质和SVD
    特征工程(转载)
    python入门基础代码
    长尾理论
    金融行业数据分析
    [rancher-net]
    rancher中使用ingress-lbs做负载均衡
    python 高级语言特性
    docker从初识到深入
    关于容器技术的发展以及虚拟化技术的总结
  • 原文地址:https://www.cnblogs.com/liu-heng/p/7517383.html
Copyright © 2011-2022 走看看