zoukankan      html  css  js  c++  java
  • mysql遍历字符串,按ASCII码拼接返回数字

    对于按照字符排序,对于排序的结果值需要运算的,可能直接order by (xxx + 0)的形式可能行不通,于是调用函数 to_number(xxx),可以对于返回数字进行排序

    DELIMITER $$
    
    USE `maventest`$$
    
    DROP FUNCTION IF EXISTS `to_number`$$
    
    CREATE DEFINER=`root`@`localhost` FUNCTION `to_number`(NAME VARCHAR(255) CHARSET gbk) RETURNS VARCHAR(4000) CHARSET gbk
    BEGIN
        DECLARE mycode INT;
        DECLARE tmp_lcode VARCHAR(2) CHARSET gbk;
        DECLARE lcode INT;
        DECLARE mypy VARCHAR(4000) CHARSET gbk DEFAULT '';
        DECLARE lp INT;
        SET mycode = 0;
        SET lp = 1;
        SET NAME = HEX(NAME);
        WHILE lp < LENGTH(NAME) DO
            SET tmp_lcode = SUBSTRING(NAME, lp, 2);
            SET lcode = CAST(ASCII(UNHEX(tmp_lcode)) AS UNSIGNED);
            IF lcode > 128 THEN
                SET lp = lp + 4;
            ELSE
                SET lp = lp + 2;
            END IF;
            SET mypy = CONCAT(mypy,lcode);
        END WHILE;
        RETURN LOWER(mypy);
    END$$
    
    DELIMITER ;


  • 相关阅读:
    WebQQ2.0 PHP
    HTML文档类型 PHP
    字符●圆角 PHP
    IIS日志分析器 PHP
    JS 像素数字 PHP
    3DTagCloud3D标签云 PHP
    QQ截屏工具提取 PHP
    .NET嵌入DLL ILMerge工具应用 PHP
    JS CSS 压缩工具(GUI界面) PHP
    Javascript 函数初探
  • 原文地址:https://www.cnblogs.com/dulinan/p/12033096.html
Copyright © 2011-2022 走看看