远古6868 2023-05-01 20:00 采纳率: 75%
浏览 27
已结题

低版本MySQL5.7如何截取数字

背景:数据库是MySQL5.7的,没有正则表达式,如何把数字截取出来。比如318、415,百度了一圈还是没有找到解决的方法

img

  • 写回答

1条回答 默认 最新

  • 创意程序员 2023-05-01 20:33
    关注

    MySQL5.7应该有正则表达式的。手头没环境不能验证,提供一个思路你试下:使用正则表达式'[0-9]+'先将数字替换成'',然后用剩余部分去替换原字段,将剩余部分替换为'',剩下数字。
    不使用正则表达式,这个函数循环每一个字符,根据ASCII码判断是否数字,返回第一个数字的位置,从1开始。没有就返回0。pData CHAR(50)为输入数据,长度可以根据需要修改:

    -- 创建函数,指定语句分隔符,不同于普通SQL语句
    DELIMITER //;
    -- 找出输入数据中第一个数字的位置
    CREATE FUNCTION first_int_index(pData CHAR(50), startPos INT)
    RETURNS INT
    BEGIN
        DECLARE vPos INT DEFAULT startPos;
        DECLARE vChar INT;
        WHILE vPos <= LENGTH(pData) DO
            SET vChar = ASCII(SUBSTR(pData,vPos,1));
            IF vChar BETWEEN 48 AND 57 THEN
                RETURN vPos;
            END IF;
            SET vPos = vPos + 1;
        END WHILE;
        RETURN 0;
    END//
    -- 找出输入数据中数字出现的长度
    CREATE FUNCTION int_length(pData CHAR(50), startPos INT)
    RETURNS INT
    BEGIN
        DECLARE vPos INT DEFAULT startPos;
        DECLARE vChar INT;
        DECLARE vLen INT DEFAULT 0;
        WHILE vPos <= LENGTH(pData) DO
            SET vChar = ASCII(SUBSTR(pData,vPos,1));
            IF vChar BETWEEN 48 AND 57 THEN
                SET vPos = vPos + 1;
                SET vLen = vLen + 1;
            ELSE
                RETURN vLen;
            END IF;
        END WHILE;
        RETURN 0;
    END//
    -- 指定回原来的语句分隔符
    DELIMITER ;//
    -- 使用函数截取数字,如果有多处数字,第二处在first_int_index中指定开始位置即可
    SELECT SUBSTR(names, first_int_index(names, 1), int_length(names, first_int_index(names))) from test20230423;
    

    如果输入数据较长,适合另一种方式,循环从0到9,每个数字到输入数据里查第一个出现的位置,如:INSTR(pData,'0'),取这些位置的最小值。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 5月10日
  • 已采纳回答 5月2日
  • 创建了问题 5月1日

悬赏问题

  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值