SQL Server - 循环访问临时表并计算多个值以将行插入第二个表

时间:2015-02-03 19:32:55

标签: sql sql-server loops sql-insert

我有一个临时表#TEMP1,它可以回收患者的下一个治疗日期以及给定日期范围内的计划治疗总数。在临时表中是一个值,它给出了每次治疗之间的最小天数。

我需要做的是采取下一个治疗日期,确定下一个治疗日期后有多少计划治疗,并用计划日期填充第二个临时表#TEMP2。

例如,在#TEMP1中,包含以下数据:

patient    next_tx_dt  planned_tx_cnt   min_days_bt   start_range  end_range
PATIENT_1  2/15/2015   4                28            2/1/2015     6/1/2015
PATIENT_2  2/05/2015   9                12            2/1/2015     6/1/2015
PATIENT_3  5/17/2015   1                112           2/1/2015     6/1/2015           

我想循环通过#TEMP1并为每一行计算计划治疗的日期。因此,一行可循环一次(PATIENT_3)或九次(PATIENT_2),每个循环在#TEMP2中产生一个新行。

成功循环后,PATIENT_1在#TEMP2中会有以下结果:

pat_id      planned_tx_dt   planned_tx_cnt
PATIENT_1   2/15/2015       1
PATIENT_1   3/15/2015       2
PATIENT_1   4/12/2015       3
PATIENT_1   5/10/2015       4

PATIENT_2有9行,PATIENT_3在#TEMP2中只有1行。

是否可以在SQL Server 2008中执行此操作?我在使用行计数之前已经完成了非常基本的循环,但这在技术上并没有循环遍历表,所以我不确定如何启动它或者甚至可能(我没有很多编写高级的经验) SQL代码)。

1 个答案:

答案 0 :(得分:0)

请务必阅读我发布的链接。同时,这是一个使用您发布的信息的功能示例。我实际上将cteTally视为我系统中的一个视图,所以我不必重新创建它。您可以根据需要调整cte部分,以确保有足够的行。

if OBJECT_ID('tempdb..#temp1') is not null
    drop table #temp1

create table #temp1
(
    patient varchar(50)
    , next_tx_dt date
    , planned_tx_cnt int
    , min_days_bt int
    , start_range date
    , end_range date    
)

insert #temp1
select 'PATIENT_1', '2/15/2015', '4', '28', '2/1/2015', '6/1/2015' union all
select 'PATIENT_2', '2/05/2015', '9', '12', '2/1/2015', '6/1/2015' union all
select 'PATIENT_3', '5/17/2015', '1', '112', '2/1/2015', '6/1/2015';

WITH
    E1(N) AS (select 1 from (values (1),(1),(1),(1),(1),(1),(1),(1),(1),(1))dt(n)),
    E2(N) AS (SELECT 1 FROM E1 a, E1 b), --10E+2 or 100 rows
    E4(N) AS (SELECT 1 FROM E2 a, E2 b), --10E+4 or 10,000 rows max
    cteTally(N) AS 
    (
        SELECT  ROW_NUMBER() OVER (ORDER BY (SELECT NULL)) FROM E4
    )

select *, DATEADD(DAY, (N - 1) * min_days_bt, next_tx_dt)
from #temp1 t1
join cteTally t on t.N <= t1.planned_tx_cnt
--where t1.patient = 'PATIENT_1'