You need to enable JavaScript to run this app.
最新活动
大模型
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

MSSQL字符串解析:从文本中提取两个数值

解决SQL Server 2012中提取格式多变字符串中数值的问题

嘿,这种格式随机的字符串提取确实容易卡壳,用SUBSTRING+CHARINDEX的话,因为分隔符不确定,确实很难覆盖所有情况。好在SQL Server的PATINDEX函数支持通配符匹配,刚好能搞定这类场景。

核心思路

利用PATINDEX定位A/B之后第一个数字的起始位置,再通过嵌套PATINDEX找到数值串的结束位置,最后用SUBSTRING提取出连续的数字串。这个方法能兼容A/B后面带符号、空格或者直接跟数字的所有变体。

具体实现代码

假设你的数据存储在表YourTableInputString字段中,执行以下查询就能得到两列目标数值:

SELECT
    -- 提取A对应的数值串NumberString1
    SUBSTRING(
        InputString,
        -- 找到A后第一个数字的起始位置
        PATINDEX('%A[^0-9]*[0-9]%', InputString) + 
        PATINDEX('%[^0-9]%', SUBSTRING(InputString, PATINDEX('%A[^0-9]*[0-9]%', InputString), LEN(InputString))) - 1,
        -- 确定数值串的长度:找到第一个非数字的位置,加空格是为了处理数值在末尾的情况
        PATINDEX('%[^0-9]%', SUBSTRING(InputString, PATINDEX('%A[^0-9]*[0-9]%', InputString), LEN(InputString)) + ' ') - 1
    ) AS NumberString1,
    -- 提取B对应的数值串NumberString2
    SUBSTRING(
        InputString,
        PATINDEX('%B[^0-9]*[0-9]%', InputString) + 
        PATINDEX('%[^0-9]%', SUBSTRING(InputString, PATINDEX('%B[^0-9]*[0-9]%', InputString), LEN(InputString))) - 1,
        PATINDEX('%[^0-9]%', SUBSTRING(InputString, PATINDEX('%B[^0-9]*[0-9]%', InputString), LEN(InputString)) + ' ') - 1
    ) AS NumberString2
FROM YourTable

逻辑拆解

  1. PATINDEX('%A[^0-9]*[0-9]%', InputString):匹配A后面跟着任意非数字字符(0个或多个)再到第一个数字的位置,精准定位数值串的起始点。
  2. 内层的PATINDEX('%[^0-9]%', ...):从起始点开始,找到第一个非数字字符的位置,以此确定数值串的长度。
  3. 末尾加空格+ ' ':防止数值串刚好在字符串末尾时,PATINDEX返回0导致提取失败。

边界情况处理

如果存在A/B缺失的情况,结果会返回NULL,你可以根据业务需求用ISNULL(..., '默认值')来替换。

内容的提问来源于stack exchange,提问作者NotADog

火山引擎 最新活动