首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何从字段中解析出不需要的文本数据

如何从字段中解析出不需要的文本数据
EN

Stack Overflow用户
提问于 2018-10-06 02:00:07
回答 1查看 40关注 0票数 1

我正在使用sequel server management studio 2014,我想知道如何才能解析出select查询的无关数据。我不希望修改数据,只是为了从其中获取SSRS数据源所需的内容,以自动执行查询。查询应该类似于下面列出的内容。

下面列出了“基于PO #105680 - Thomas Test GRPO接收验证查询测试”注释字段中的值的一个示例。

理想情况下,我只需要值'105680‘,这样我就可以将其用作查找引用。任何帮助都将一如既往地受到感谢。

代码语言:javascript
复制
SELECT
   [DocEntry]
  ,[DocNum]
  ,[DocType]
  ,[CANCELED]
  ,[Comments]
  FROM [Billy].[dbo].[OPDN]
EN

回答 1

Stack Overflow用户

发布于 2018-10-06 02:44:40

您可以使用CHARINDEX在文本中查找PO #,然后SUBSTRING解析出数字,只要格式一致即可。

代码语言:javascript
复制
;WITH TEMP AS (SELECT  'Based on PO #105680 - Thomas Test GRPO Reciept Validation query test' AS comment )

SELECT comment, 
    CASE WHEN TEMP.comment LIKE '%PO #%' THEN SUBSTRING(TEMP.comment, CHARINDEX('PO #', TEMP.comment) + 4, CHARINDEX('PO #', TEMP.comment, CHARINDEX(' ', TEMP.comment) + 1) - 4) END AS PO_NUM
FROM TEMP

您的查询将如下所示

代码语言:javascript
复制
SELECT
   [DocEntry]
  ,[DocNum]
  ,[DocType]
  ,[CANCELED]
  ,[Comments]
  ,CASE WHEN Comments LIKE '%PO #%' THEN SUBSTRING(Comments, CHARINDEX('PO #', Comments) + 4, CHARINDEX('PO #', Comments, CHARINDEX(' ', Comments) + 1) - 4) END AS PO_NUM
FROM [Billy].[dbo].[OPDN]
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52671051

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档