背景:数据库是MySQL5.7的,没有正则表达式,如何把数字截取出来。比如318、415,百度了一圈还是没有找到解决的方法
低版本MySQL5.7如何截取数字
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
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'),取这些位置的最小值。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥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,出参布尔值