标签: mysql sql parsing alphanumeric
我有一个表tab1,其列col1具有复合的alpha-then-numeric值,如下所示:
tab1
col1
abc123 xy45 def6 z9
我需要在查询中将值提取为单独的列,并将数字部分放在整数数据类型的列中。
如果两个值具有一致的开始和结束位置,则可以使用substring()完成作业,因为您可以看到数字部分的开头不同。
substring()
是否有一种优雅的方法可以解决这个问题,或者必须使用正则表达式匹配来分隔案例,或者在一个巨大的案例陈述中汇总每个可能起点的一系列联合吗?
答案 0 :(得分:4)
是的,它是:
SELECT @col:=col1 AS col, @num:=REVERSE(CAST(REVERSE(@col) AS UNSIGNED)) AS num, SUBSTRING_INDEX(@col, @num, 1) AS word FROM tab1
- 只有当你的专栏包含字母和数字时才会起作用(就像你所描述的那样)。这就是为什么需要加倍REVERSE()(否则CAST()将无效)。请检查此demo。
REVERSE()
CAST()