首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >子串和CHARINDEX

子串和CHARINDEX
EN

Stack Overflow用户
提问于 2016-05-09 06:52:51
回答 1查看 359关注 0票数 0

我需要将“目标输液率:###”放入它自己的字段中。

我正在尝试这个代码子字符串(summaryline,CHARINDEX('Infusion:',summaryline),+14),但是它不工作。

代码语言:javascript
复制
, Initial Rate:  40, Goal Rate of Infusion:  0, to goal rate in 8 hours
, Initial Rate:  30, Goal Rate of Infusion:  0, to goal rate in 8 hours
, Initial Rate:  10, Goal Rate of Infusion:  10, to goal rate in 8 hours, HOLD FOR N/V
, Initial Rate:  40, Goal Rate of Infusion:  10, to goal rate in 8 hours
, Initial Rate:  40, Goal Rate of Infusion:  10, to goal rate in 8 hours
, Initial Rate:  100, Goal Rate of Infusion:  100, to goal rate in 8 hours
, Initial Rate:  15, Goal Rate of Infusion:  15, to goal rate in 8 hours
, Initial Rate:  40, Goal Rate of Infusion:  15, to goal rate in 8 hours
EN

回答 1

Stack Overflow用户

发布于 2016-05-09 07:20:00

代码语言:javascript
复制
SELECT
    SummaryLine,
    StartIdx,
    EndIdx,
    CONVERT(
        int,
        SUBSTRING( SummaryLine, StartIdx, EndIdx - StartIdx )
    ) AS InfusionRate
FROM (
    SELECT
        SummaryLine,
        StartIdx,
        CHARINDEX(',', summaryLine, StartIdx) AS EndIdx
    FROM (
        SELECT
            SummaryLine,
            CHARINDEX('Infusion:', SummaryLine) + 10 AS StartIdx,
        FROM
            SourceTable
    )
)

或作为单行:

代码语言:javascript
复制
SELECT
    CONVERT(
        int,
        SUBSTRING(
            SummaryLine,
            CHARINDEX('Infusion:', summaryLine) + 10,
            CHARINDEX(
                ',',
                SummaryLine,
                CHARINDEX('Infusion:', summaryLine) + 10
            )
        )
    )
FROM
    SourceTable

不幸的是,SQL不允许您在单个SELECT语句中缓存或别名表达式结果-您需要使用子查询(第一个示例)或重复表达式(第二个示例)。

更新:我做了一些研究,你可以使用CROSS APPLY计算StartIdx只有一次:

代码语言:javascript
复制
SELECT
    SummaryLine,
    CONVERT(
        int,
        SUBSTRING(
            SummaryLine,
            StartIdx,
            CHARINDEX(',', summaryLine, StartIdx) - StartIdx
        )
    ) AS InfusionRate
FROM
    SourceTable
    CROSS APPLY (
        SELECT CHARINDEX('Infusion:', summaryLine) + 10 AS StartIdx
    )
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37105651

复制
相关文章

相似问题

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