繁体   English   中英

SUBSTRING和CHARINDEX

[英]SUBSTRING AND CHARINDEX

我需要在自己的字段中输入“目标输注率:###”

我正在尝试此代码Substring(SummaryLine,CHARINDEX('Infusion:',summaryline),+ 14),但是它不起作用。

, 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
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
    )
)

或作为一行:

SELECT
    CONVERT(
        int,
        SUBSTRING(
            SummaryLine,
            CHARINDEX('Infusion:', summaryLine) + 10,
            CHARINDEX(
                ',',
                SummaryLine,
                CHARINDEX('Infusion:', summaryLine) + 10
            )
        )
    )
FROM
    SourceTable

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

更新:我做了一些研究,您只能使用CROSS APPLY来计算StartIdx

SELECT
    SummaryLine,
    CONVERT(
        int,
        SUBSTRING(
            SummaryLine,
            StartIdx,
            CHARINDEX(',', summaryLine, StartIdx) - StartIdx
        )
    ) AS InfusionRate
FROM
    SourceTable
    CROSS APPLY (
        SELECT CHARINDEX('Infusion:', summaryLine) + 10 AS StartIdx
    )

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM