Boh*_*ian 6 mysql sql parsing alphanumeric
我有一个表tab1,其列col1具有复合的alpha-then-numeric值,如下所示:
abc123
xy45
def6
z9
Run Code Online (Sandbox Code Playgroud)
我需要在查询中将值提取为单独的列,并将数字部分放在整数数据类型的列中.
如果两个值具有一致的开始和结束位置,则可以完成作业substring(),因为您可以看到数字部分的开头不同.
是否有一种优雅的方法可以解决这个问题,或者必须使用正则表达式匹配来分离案例,或者在一个巨大的案例陈述中汇总每个可能起点的一系列联盟?
是的:
SELECT
@col:=col1 AS col,
@num:=REVERSE(CAST(REVERSE(@col) AS UNSIGNED)) AS num,
SUBSTRING_INDEX(@col, @num, 1) AS word
FROM
tab1
Run Code Online (Sandbox Code Playgroud)
- 仅当您的列包含字母和数字(如您所描述的那样)时才有效。这就是为什么REVERSE()需要double (否则CAST()将无效)。检查这个演示。
| 归档时间: |
|
| 查看次数: |
1223 次 |
| 最近记录: |