From 3b19d3fa100ca6f6143d64acaca0e9fe465eff4b Mon Sep 17 00:00:00 2001 From: Mugo Date: Mon, 15 Jul 2024 09:46:22 +0300 Subject: [PATCH 1/4] Added FactHistoricalViralLoad script. Yet to add PBFW logi --- .../FactHistoricalViralLoad.sql | 191 ++++++++++++++++++ 1 file changed, 191 insertions(+) create mode 100644 Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql diff --git a/Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql b/Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql new file mode 100644 index 00000000..3f352395 --- /dev/null +++ b/Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql @@ -0,0 +1,191 @@ +TRUNCATE TABLE ndwh.dbo.FactViralLoad_Hist; + +DECLARE @start_date DATE; + +SELECT @start_date = dateadd(month, -12, eomonth(dateadd(month, -2, getdate()))); + +DECLARE @end_date DATE; + +SELECT @end_date = eomonth(dateadd(month, -2, getdate())); + +--- create a temp table to store end of month for each month +with dates as ( + SELECT datefromparts(year(@start_date), month(@start_date), 1) as dte + UNION ALL + SELECT dateadd(month, 1, dte) --incrementing month by month until the date is less than or equal to @end_date + FROM dates + WHERE dateadd(month, 1, dte) <= @end_date + ) +SELECT + eomonth(dte) as end_date +INTO #months +FROM dates +OPTION (maxrecursion 0); + +--declare as of date +DECLARE @as_of_date As DATE; + +--declare cursor +DECLARE cursor_AsOfDates CURSOR FOR +SELECT * FROM #months + +OPEN cursor_AsOfDates + +FETCH NEXT FROM cursor_AsOfDates INTO @as_of_date +WHILE @@FETCH_STATUS = 0 + +BEGIN +WITH viralLoad As ( + SELECT DISTINCT + Labs.PatientPk, + Labs.SiteCode, + VisitID, + art.StartARTDate, + [OrderedbyDate], + [ReportedbyDate], + Patient.DOB, + AgeAsOfDate = Datediff(year,Patient.DOB,@as_of_date), + [TestName], + TestResult, + Labs.[Emr], + Labs.[Project], + CASE + WHEN datediff(month,art.StartARTDate, @as_of_date) >=3 THEN 1 + WHEN DATEDIFF(MONTH, art.StartARTDate, @as_of_date) <3 THEN 0 + END As EligibleVL, + CASE + WHEN datediff(month,[OrderedbyDate],@as_of_date) <= 6 and Datediff(year,Patient.DOB,@as_of_date) <= 24 THEN 1 + WHEN datediff(month,[OrderedbyDate],@as_of_date) <= 12 and Datediff(year,Patient.DOB,@as_of_date) > 24 THEN 1 + ELSE 0 + END As IsValidVL, + CASE + WHEN IsNumeric([TestResult]) = 1 THEN + CASE + WHEN cast(replace([TestResult], ',', '') as float) < 200.00 THEN 1 + ELSE 0 + END + ELSE + CASE + WHEN [TestResult] in ('undetectable','NOT DETECTED','0 copies/ml','LDL','Less than Low Detectable Level') THEN 1 + ELSE 0 + END + END as VLSup, + @as_of_date As AsOfDate, + getdate() As LoadDate + ---into ndwh.dbo.FactViralLoad_Hist + FROM ODS.dbo.CT_ARTPatients art + join ODS.dbo.CT_PatientLabs Labs ---Visits to know whether the the pregnant or not(Pbfw) + ON art.PatientPK = labs.Patientpk and + art.SiteCode = labs.SiteCode + Left join ODS.dbo.CT_patient patient + on art.PatientPK = patient.Patientpk and + art.SiteCode = patient.SiteCode + + where TestName = 'Viral Load' + and TestName <>'CholesterolLDL (mmol/L)' and TestName <> 'Hepatitis C viral load' + and TestResult is not null + and Labs.SiteCode =12601 and art.PatientPK = 10 + and [OrderedbyDate] <= @as_of_date + ), + +Visits As( + +select Visits.SiteCode, + Visits.PatientPK, + VisitDate,Pregnant, + Breastfeeding, + NextAppointmentDate , + @as_of_date As AsOfDate + from ODS.DBO.CT_PatientVisits Visits + join viralLoad + on Visits.SiteCode = viralLoad.Sitecode and Visits.PatientPK = viralLoad.PatientPK +where Visits.VisitDate <= @as_of_date and Visits.SiteCode =12601 and Visits.PatientPK = 10 + +), + +MaxVisitsByAsOf As ( + select + row_number() over(partition by SiteCode, PatientPK,AsOfDate order by VisitDate desc) as rank, + SiteCode, + PatientPK, + VisitDate, + AsOfDate, + NextAppointmentDate, + Pregnant, + Breastfeeding + from Visits +), +RankMaxVisitDateAsOf As( +select SiteCode,PatientPK, VisitDate,Pregnant,Breastfeeding,NextAppointmentDate,AsOfDate +from MaxVisitsByAsOf +where rank =1 + + +), + +MaxOrderedbyDateByAsOfDate As ( + select + row_number() over(partition by SiteCode, PatientPK,AsOfDate order by [OrderedbyDate] desc) as rank, + SiteCode, + PatientPK, + StartARTDate, + DOB, + AgeAsOfDate, + [OrderedbyDate], + [ReportedbyDate], + EligibleVL, + IsValidVL, + VLSup, + AsOfDate, + [TestName], + TestResult, + [Emr], + [Project] + from viralLoad + where [OrderedbyDate] <= AsOfDate + + ), +MaxOrderedbyDateByAsOfDate_Final As ( +select SiteCode,PatientPK,StartARTDate,DOB,AgeAsOfDate,OrderedbyDate,ReportedbyDate,EligibleVL,IsValidVL,VLSup,AsOfDate,TestName,TestResult,Emr,Project +from MaxOrderedbyDateByAsOfDate +where rank =1 + +), +Combined As( + Select OrderedFinal.SiteCode,OrderedFinal.PatientPK,StartARTDate,DOB,AgeAsOfDate,OrderedbyDate,MaxVisitAsOf.VisitDate,MaxVisitAsOf.Pregnant,MaxVisitAsOf.Breastfeeding,ReportedbyDate,EligibleVL,IsValidVL,VLSup,OrderedFinal.AsOfDate,TestName,TestResult,Emr,Project + from MaxOrderedbyDateByAsOfDate_Final OrderedFinal + join RankMaxVisitDateAsOf MaxVisitAsOf + on OrderedFinal.SiteCode = MaxVisitAsOf.SiteCode and OrderedFinal.PatientPK = MaxVisitAsOf.PatientPK + and OrderedFinal.AsOfDate = MaxVisitAsOf.AsOfDate + +) + +insert into ndwh.dbo.FactViralLoad_Hist( SiteCode,PatientPK,StartARTDate,DOB,VisitDate,Pregnant,Breastfeeding,AgeAsOfDate,OrderedbyDate,ReportedbyDate,EligibleVL,IsValidVL,VLSup,AsOfDate,TestName,TestResult,Emr,Project) + +select SiteCode,PatientPK,StartARTDate,DOB,VisitDate,Pregnant,Breastfeeding,AgeAsOfDate,OrderedbyDate,ReportedbyDate,EligibleVL,IsValidVL,VLSup,AsOfDate,TestName,TestResult,Emr,Project +from Combined + +Update a +set IsPBFW= case + WHEN (Pregnant ='yes' or Breastfeeding ='yes') THEN 1 + ELSE 0 + END +from ndwh.dbo.FactViralLoad_Hist a; + +Update a +set IsValidVL= case + WHEN datediff(month,[OrderedbyDate],a.AsOfDate) <= 6 THEN 1 + END +from ndwh.dbo.FactViralLoad_Hist a +where IsPBFW = 1 + + + +fetch next from cursor_AsOfDates into @as_of_date +end +drop table #months +close cursor_AsOfDates +deallocate cursor_AsOfDates + + + From 66c03d529f6ea0fd1d57af28740e7354c9b94db4 Mon Sep 17 00:00:00 2001 From: Mugo Date: Mon, 29 Jul 2024 16:55:04 +0300 Subject: [PATCH 2/4] Added a new model CsLinelistHistoricalViralLoad --- .../FactHistoricalViralLoad.sql | 202 +++++++++++++----- .../Load_Cs_LinelistHistoricalViralLoad.sql | 36 ++++ 2 files changed, 183 insertions(+), 55 deletions(-) create mode 100644 Scripts/REPORTING/HIVCaseSurveillance/Load_Cs_LinelistHistoricalViralLoad.sql diff --git a/Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql b/Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql index 3f352395..5299575e 100644 --- a/Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql +++ b/Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql @@ -2,11 +2,11 @@ TRUNCATE TABLE ndwh.dbo.FactViralLoad_Hist; DECLARE @start_date DATE; -SELECT @start_date = dateadd(month, -12, eomonth(dateadd(month, -2, getdate()))); +SELECT @start_date = dateadd(month, -12, eomonth(dateadd(month, -1, getdate()))); DECLARE @end_date DATE; -SELECT @end_date = eomonth(dateadd(month, -2, getdate())); +SELECT @end_date = eomonth(dateadd(month, -1, getdate())); --- create a temp table to store end of month for each month with dates as ( @@ -20,6 +20,7 @@ SELECT eomonth(dte) as end_date INTO #months FROM dates + OPTION (maxrecursion 0); --declare as of date @@ -37,8 +38,9 @@ WHILE @@FETCH_STATUS = 0 BEGIN WITH viralLoad As ( SELECT DISTINCT - Labs.PatientPk, - Labs.SiteCode, + patient.PatientPk, + patient.PatientPkHash, + patient.SiteCode, VisitID, art.StartARTDate, [OrderedbyDate], @@ -57,50 +59,33 @@ WITH viralLoad As ( WHEN datediff(month,[OrderedbyDate],@as_of_date) <= 6 and Datediff(year,Patient.DOB,@as_of_date) <= 24 THEN 1 WHEN datediff(month,[OrderedbyDate],@as_of_date) <= 12 and Datediff(year,Patient.DOB,@as_of_date) > 24 THEN 1 ELSE 0 - END As IsValidVL, - CASE - WHEN IsNumeric([TestResult]) = 1 THEN - CASE - WHEN cast(replace([TestResult], ',', '') as float) < 200.00 THEN 1 - ELSE 0 - END - ELSE - CASE - WHEN [TestResult] in ('undetectable','NOT DETECTED','0 copies/ml','LDL','Less than Low Detectable Level') THEN 1 - ELSE 0 - END - END as VLSup, + END As IsValidVL, + 0 as VLSup, @as_of_date As AsOfDate, getdate() As LoadDate - ---into ndwh.dbo.FactViralLoad_Hist - FROM ODS.dbo.CT_ARTPatients art - join ODS.dbo.CT_PatientLabs Labs ---Visits to know whether the the pregnant or not(Pbfw) + FROM ODS.dbo.CT_patient patient + INNER join ODS.dbo.CT_ARTPatients art + on art.PatientPK = patient.Patientpk and + art.SiteCode = patient.SiteCode + left join ODS.dbo.CT_PatientLabs Labs ON art.PatientPK = labs.Patientpk and art.SiteCode = labs.SiteCode - Left join ODS.dbo.CT_patient patient - on art.PatientPK = patient.Patientpk and - art.SiteCode = patient.SiteCode - - where TestName = 'Viral Load' - and TestName <>'CholesterolLDL (mmol/L)' and TestName <> 'Hepatitis C viral load' - and TestResult is not null - and Labs.SiteCode =12601 and art.PatientPK = 10 - and [OrderedbyDate] <= @as_of_date + where NullIf('2000-01-01',[OrderedbyDate]) <= @as_of_date ), - + Visits As( select Visits.SiteCode, Visits.PatientPK, VisitDate,Pregnant, Breastfeeding, + LMP, NextAppointmentDate , @as_of_date As AsOfDate from ODS.DBO.CT_PatientVisits Visits join viralLoad on Visits.SiteCode = viralLoad.Sitecode and Visits.PatientPK = viralLoad.PatientPK -where Visits.VisitDate <= @as_of_date and Visits.SiteCode =12601 and Visits.PatientPK = 10 - +where Visits.VisitDate <= @as_of_date ), MaxVisitsByAsOf As ( @@ -112,15 +97,48 @@ MaxVisitsByAsOf As ( AsOfDate, NextAppointmentDate, Pregnant, - Breastfeeding + Breastfeeding, + LMP from Visits ), RankMaxVisitDateAsOf As( -select SiteCode,PatientPK, VisitDate,Pregnant,Breastfeeding,NextAppointmentDate,AsOfDate +select SiteCode,PatientPK, VisitDate,Pregnant,Breastfeeding,LMP,NextAppointmentDate,AsOfDate from MaxVisitsByAsOf where rank =1 +), +VlSupBasedOfValidity As( + Select SiteCode, + PatientPK, + PatientPkHash, + StartARTDate, + DOB, + AgeAsOfDate, + [OrderedbyDate], + [ReportedbyDate], + EligibleVL, + IsValidVL, + CASE + WHEN IsNumeric([TestResult]) = 1 and IsValidVL=1 THEN + CASE + WHEN try_cast(replace([TestResult], ',', '') as float) < 200.00 THEN 1 + ELSE 0 + END + ELSE + CASE + WHEN [TestResult] in ('undetectable','NOT DETECTED','0 copies/ml','LDL','Less than Low Detectable Level') and IsValidVL=1 THEN 1 + ELSE 0 + END + END as VLSup, + AsOfDate, + [TestName], + TestResult, + [Emr], + [Project] + + from viralLoad + where NullIf('2000-01-01',[OrderedbyDate]) <= AsOfDate ), MaxOrderedbyDateByAsOfDate As ( @@ -128,6 +146,7 @@ MaxOrderedbyDateByAsOfDate As ( row_number() over(partition by SiteCode, PatientPK,AsOfDate order by [OrderedbyDate] desc) as rank, SiteCode, PatientPK, + PatientPkHash, StartARTDate, DOB, AgeAsOfDate, @@ -141,43 +160,116 @@ MaxOrderedbyDateByAsOfDate As ( TestResult, [Emr], [Project] - from viralLoad - where [OrderedbyDate] <= AsOfDate + from VlSupBasedOfValidity + where NullIf('2000-01-01',[OrderedbyDate]) <= AsOfDate ), MaxOrderedbyDateByAsOfDate_Final As ( -select SiteCode,PatientPK,StartARTDate,DOB,AgeAsOfDate,OrderedbyDate,ReportedbyDate,EligibleVL,IsValidVL,VLSup,AsOfDate,TestName,TestResult,Emr,Project +select SiteCode,PatientPK,PatientPkHash,StartARTDate,DOB,AgeAsOfDate,OrderedbyDate,ReportedbyDate,EligibleVL,IsValidVL,VLSup,AsOfDate,TestName,TestResult,Emr,Project from MaxOrderedbyDateByAsOfDate where rank =1 -), +) + +, Combined As( - Select OrderedFinal.SiteCode,OrderedFinal.PatientPK,StartARTDate,DOB,AgeAsOfDate,OrderedbyDate,MaxVisitAsOf.VisitDate,MaxVisitAsOf.Pregnant,MaxVisitAsOf.Breastfeeding,ReportedbyDate,EligibleVL,IsValidVL,VLSup,OrderedFinal.AsOfDate,TestName,TestResult,Emr,Project + Select OrderedFinal.SiteCode,OrderedFinal.PatientPK,OrderedFinal.PatientPkHash,StartARTDate,DOB,AgeAsOfDate,OrderedbyDate,MaxVisitAsOf.VisitDate,MaxVisitAsOf.Pregnant,MaxVisitAsOf.Breastfeeding,LMP,ReportedbyDate,EligibleVL,IsValidVL,VLSup,OrderedFinal.AsOfDate,TestName,TestResult,Emr,Project from MaxOrderedbyDateByAsOfDate_Final OrderedFinal join RankMaxVisitDateAsOf MaxVisitAsOf on OrderedFinal.SiteCode = MaxVisitAsOf.SiteCode and OrderedFinal.PatientPK = MaxVisitAsOf.PatientPK and OrderedFinal.AsOfDate = MaxVisitAsOf.AsOfDate +), +Combined_PBFW As( +Select SiteCode, + PatientPK, + PatientPkHash, + StartARTDate, + DOB, + AgeAsOfDate, + OrderedbyDate, + VisitDate, + Pregnant, + Breastfeeding, + LMP, + ReportedbyDate, + EligibleVL, + IsPBFW= case + WHEN (Pregnant ='yes' or Breastfeeding ='yes') THEN 1 + ELSE 0 + END, + IsValidVL, + VLSup, + AsOfDate, + TestName, + TestResult, + Emr, + Project + from Combined + ) -insert into ndwh.dbo.FactViralLoad_Hist( SiteCode,PatientPK,StartARTDate,DOB,VisitDate,Pregnant,Breastfeeding,AgeAsOfDate,OrderedbyDate,ReportedbyDate,EligibleVL,IsValidVL,VLSup,AsOfDate,TestName,TestResult,Emr,Project) +insert into ndwh.dbo.FactViralLoad_Hist(PatientKey, + FacilityKey, + AgeGroupKey, + SiteCode, + VisitDate, + Pregnant, + Breastfeeding, + LMP, + AgeAsOfDate, + OrderedbyDate, + ReportedbyDate, + EligibleVL, + IsPBFW, + IsValidVL, + VLSup, + AsOfDate, + TestName, + TestResult, + Emr, + Project + ) -select SiteCode,PatientPK,StartARTDate,DOB,VisitDate,Pregnant,Breastfeeding,AgeAsOfDate,OrderedbyDate,ReportedbyDate,EligibleVL,IsValidVL,VLSup,AsOfDate,TestName,TestResult,Emr,Project -from Combined +select Patient.PatientKey, + Facility.FacilityKey, + AgeGroup.AgeGroupKey, + Combined_PBFW.SiteCode, + VisitDate, + Pregnant, + Breastfeeding, + LMP, + AgeAsOfDate, + OrderedbyDate, + ReportedbyDate, + EligibleVL, + IsPBFW, + IsValidVL, + VLSup, + AsOfDate, + TestName, + TestResult, + Combined_PBFW.Emr, + Combined_PBFW.Project +from Combined_PBFW +left join NDWH.dbo.DimPatient Patient + on Combined_PBFW.SiteCode = Patient.SiteCode and Combined_PBFW.PatientPkHash = Patient.PatientPKHash +Left join NDWH.dbo.DimFacility Facility + on Combined_PBFW.SiteCode = Facility.MFLCode +left join [NDWH].[dbo].[DimAgeGroup] AgeGroup + on Combined_PBFW.AgeAsOfDate = AgeGroup.Age -Update a -set IsPBFW= case - WHEN (Pregnant ='yes' or Breastfeeding ='yes') THEN 1 - ELSE 0 - END -from ndwh.dbo.FactViralLoad_Hist a; - -Update a -set IsValidVL= case - WHEN datediff(month,[OrderedbyDate],a.AsOfDate) <= 6 THEN 1 - END -from ndwh.dbo.FactViralLoad_Hist a -where IsPBFW = 1 +--Update a +--set IsValidVL= 0 +--from ndwh.dbo.FactViralLoad_Hist a +--where IsPBFW = 1; + +--Update a +--set IsValidVL= case +-- WHEN datediff(month,[OrderedbyDate],a.AsOfDate) <= 6 THEN 1 +-- END +--from ndwh.dbo.FactViralLoad_Hist a +--where IsPBFW = 1 diff --git a/Scripts/REPORTING/HIVCaseSurveillance/Load_Cs_LinelistHistoricalViralLoad.sql b/Scripts/REPORTING/HIVCaseSurveillance/Load_Cs_LinelistHistoricalViralLoad.sql new file mode 100644 index 00000000..a7202ad4 --- /dev/null +++ b/Scripts/REPORTING/HIVCaseSurveillance/Load_Cs_LinelistHistoricalViralLoad.sql @@ -0,0 +1,36 @@ +IF OBJECT_ID(N'[HIVCaseSurveillance].[dbo].[CsLinelistHistoricalViralLoad]', N'U') IS NOT NULL + DROP TABLE [HIVCaseSurveillance].[dbo].[CsLinelistHistoricalViralLoad]; + + +BEGIN + SELECT Facility.FacilityName + ,Facility.MFLCode + ,Facility.County + ,Facility.SubCounty + ,Patient.PatientPKHash + ,Patient.Gender + ,Patient.DOB + ,AsOfDate + ,AgeAsOfDate + ,[AgeGroup].DATIMAgeGroup + ,YEAR(TRY_CAST(DateConfirmedHIVPositiveKey AS DATE)) As CohortYear + ,TRY_CAST(DateConfirmedHIVPositiveKey AS DATE) As CohortYearMonth + ,cast(DateConfirmedHIVPositiveKey as date) As OutcomeYearMonth + ,EligibleVL As VLEligibility + ,IsValidVL As VLValidity + ,VLSup As VLSuppression + INTO [HIVCaseSurveillance].[dbo].[CsLinelistHistoricalViralLoad] + FROM ndwh.dbo.FactViralLoad_Hist FactViralLoad_Hist + LEFT OUTER JOIN [NDWH].[dbo].[DimFacility] Facility + ON FactViralLoad_Hist.FacilityKey = Facility.FacilityKey + LEFT OUTER JOIN [NDWH].[dbo].[DimPatient] Patient + on FactViralLoad_Hist.PatientKey = Patient.PatientKey + LEFT OUTER JOIN [NDWH].[dbo].[DimDate] [Date] + ON FactViralLoad_Hist.AsOfDate = [Date].[Date] + LEFT OUTER JOIN [NDWH].[dbo].[DimAgeGroup] [AgeGroup] + ON FactViralLoad_Hist.AgeGroupKey = [AgeGroup].AgeGroupKey + where YEAR(DateConfirmedHIVPositiveKey) <= YEAR(GETDATE()) + + ORDER BY DateConfirmedHIVPositiveKey DESC; +END + From 6cf74f5e8f8749ca525a71d24db30bc1e7630ab1 Mon Sep 17 00:00:00 2001 From: Mugo Date: Fri, 2 Aug 2024 21:39:44 +0300 Subject: [PATCH 3/4] Aligned the historical fact viral load and all the computions aligned including the PBFW --- .../FactHistoricalViralLoad.sql | 358 ++++++++++++++++++ .../Load_Cs_LinelistHistoricalViralLoad.sql | 2 + 2 files changed, 360 insertions(+) diff --git a/Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql b/Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql index 5299575e..9f1cae17 100644 --- a/Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql +++ b/Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql @@ -281,3 +281,361 @@ deallocate cursor_AsOfDates +TRUNCATE TABLE ndwh.dbo.FactViralLoad_Hist; + +DECLARE @start_date DATE; + +SELECT @start_date = dateadd(month, -12, eomonth(dateadd(month, -2, getdate()))); + +DECLARE @end_date DATE; + +SELECT @end_date = eomonth(dateadd(month, -2, getdate())); + +--- create a temp table to store end of month for each month +with dates as ( + SELECT datefromparts(year(@start_date), month(@start_date), 1) as dte + UNION ALL + SELECT dateadd(month, 1, dte) --incrementing month by month until the date is less than or equal to @end_date + FROM dates + WHERE dateadd(month, 1, dte) <= @end_date + ) +SELECT + eomonth(dte) as end_date +INTO #months +FROM dates + + +OPTION (maxrecursion 0); + +--declare as of date +DECLARE @as_of_date As DATE; + +--declare cursor +DECLARE cursor_AsOfDates CURSOR FOR +SELECT * FROM #months + +OPEN cursor_AsOfDates + +FETCH NEXT FROM cursor_AsOfDates INTO @as_of_date +WHILE @@FETCH_STATUS = 0 + +BEGIN +WITH PatientStartedOnART As ( + SELECT DISTINCT + patient.PatientPKHash, + art.PatientPK, + patient.SiteCode, + Cast(art.StartARTDate as Date) As StartARTDate, + patient.DateConfirmedHIVPositiveKey As CohortYearMonth, + year(patient.DateConfirmedHIVPositiveKey) As CohortYear, + Patient.DOB, + 0 AS EligibleVL, + 0 As IsValidVL, + 0 as VLSup, + @as_of_date As AsOfDate, + getdate() As LoadDate + FROM ndwh.dbo.DimPatient patient + INNER join ODS.dbo.CT_ARTPatients art + on art.PatientPKHash = patient.PatientPKHash and + art.SiteCode = patient.SiteCode and patient.voided = 0 + ), +ViralLoadOrdered As ( + select SiteCode + ,PatientPK + ,VisitID + ,OrderedbyDate + ,ReportedbyDate + ,TestName + ,TestResult + ,Emr + ,Project + ,PatientPKHash + ,Reason + ,@as_of_date As AsOfDate + from ods.dbo.Intermediate_OrderedViralLoads OrderedViralLoads + where OrderedbyDate <=@as_of_date + +), +MaxViralLoadOrderedByAsOfDate As ( + select + row_number() over(partition by SiteCode, PatientPK,AsOfDate order by [OrderedbyDate] desc) as rank, + SiteCode, + PatientPK, + PatientPkHash, + [OrderedbyDate], + [ReportedbyDate], + AsOfDate, + [TestName], + TestResult, + [Emr], + [Project] + from ViralLoadOrdered + where NullIf('2000-01-01',[OrderedbyDate]) <= AsOfDate + + ), +MaxOrderedbyDateByAsOfDate_Final As ( + select SiteCode + ,PatientPK + ,PatientPkHash + ,OrderedbyDate + ,ReportedbyDate + ,AsOfDate + ,TestName + ,TestResult + ,Emr + ,Project + from MaxViralLoadOrderedByAsOfDate + where rank =1 + ), + +Combined As( + Select PatientStartedOnART.SiteCode + ,PatientStartedOnART.PatientPK + ,PatientStartedOnART.PatientPkHash + ,CohortYearMonth + ,CohortYear + ,StartARTDate + ,DOB + ,AgeAsOfDate = Datediff(year,PatientStartedOnART.DOB,@as_of_date) + ,OrderedFinal.OrderedbyDate + ,OrderedFinal.ReportedbyDate + ,PatientStartedOnART.AsOfDate + ,TestName + ,TestResult + ,Emr + ,Project + from PatientStartedOnART + left join MaxOrderedbyDateByAsOfDate_Final OrderedFinal + on PatientStartedOnART.SiteCode = OrderedFinal.SiteCode and + PatientStartedOnART.PatientPK = OrderedFinal.PatientPK + +), +EligibleVLCheck As ( + select SiteCode, + PatientPK + ,PatientPkHash + ,StartARTDate + ,CohortYearMonth + ,CohortYear + ,DOB + ,AgeAsOfDate + ,OrderedbyDate + ,ReportedbyDate + ,AsOfDate + ,TestName + ,TestResult + ,Emr + ,Project + ,EligibleVL = CASE + WHEN datediff(month,Combined.StartARTDate, @as_of_date) >=3 THEN 1 + WHEN DATEDIFF(MONTH, Combined.StartARTDate, @as_of_date) <3 THEN 0 + END + from Combined + ), +VLValidityCheckBasedOnEligibilityAndAge As ( + select SiteCode, + PatientPK + ,PatientPkHash + ,StartARTDate + ,CohortYearMonth + ,CohortYear + ,DOB + ,AgeAsOfDate + ,OrderedbyDate + ,ReportedbyDate + ,AsOfDate + ,TestName + ,TestResult + ,Emr + ,Project + ,EligibleVL + ,IsValidVL = CASE + WHEN datediff(month,[OrderedbyDate],@as_of_date) <= 6 and Datediff(year,AgeAsOfDate,@as_of_date) <= 24 and EligibleVLCheck.EligibleVL =1 THEN 1 + WHEN datediff(month,[OrderedbyDate],@as_of_date) <= 12 and Datediff(year,AgeAsOfDate,@as_of_date) > 24 and EligibleVLCheck.EligibleVL = 1 THEN 1 + ELSE 0 + END + from EligibleVLCheck + +), +VLSupCheck As ( + select SiteCode, + PatientPK + ,PatientPkHash + ,StartARTDate + ,CohortYearMonth + ,CohortYear + ,DOB + ,AgeAsOfDate + ,OrderedbyDate + ,ReportedbyDate + ,AsOfDate + ,TestName + ,TestResult + ,Emr + ,Project + ,EligibleVL + ,IsValidVL + ,0 VLSup + from VLValidityCheckBasedOnEligibilityAndAge + +), +CombineVLSupCheckAndPBFW As( + select distinct a.SiteCode, + a.PatientPK + ,a.PatientPkHash + ,StartARTDate + ,CohortYearMonth + ,CohortYear + ,DOB + ,AgeAsOfDate + ,OrderedbyDate + ,ReportedbyDate + ,a.AsOfDate + ,TestName + ,TestResult + ,Emr + ,Project + ,EligibleVL + ,IsValidVL + ,b.IsPBFW + ,0 VLSup + from VLValidityCheckBasedOnEligibilityAndAge a + left join [ODS].[dbo].[Intermediate_PregnantAndBreastFeeding] b + on a.SiteCode = b.SiteCode and a.PatientPK = b.PatientPK + +), +Combine_PBFWListing_VLSupCheck As ( + select SiteCode + ,PatientPK + ,PatientPkHash + ,StartARTDate + ,CohortYearMonth + ,CohortYear + ,AgeAsOfDate + ,OrderedbyDate + ,ReportedbyDate + ,AsOfDate + ,TestName + ,TestResult + ,Emr + ,Project + ,EligibleVL + ,IsValidVL = CASE + WHEN datediff(month,[OrderedbyDate],@as_of_date) <= 6 and IsPBFW=1 THEN 1 + ELSE IsValidVL + END + ,VLSup + ,IsPBFW + from CombineVLSupCheckAndPBFW + +), +CombinedValidityCheck As ( + select SiteCode, + PatientPK + ,PatientPkHash + ,StartARTDate + ,CohortYearMonth + ,CohortYear + ,AgeAsOfDate + ,OrderedbyDate + ,ReportedbyDate + ,AsOfDate + ,TestName + ,TestResult + ,Emr + ,Project + ,EligibleVL + ,IsValidVL + ,VLSup = CASE + WHEN IsNumeric([TestResult]) = 1 THEN + CASE + WHEN cast(replace([TestResult], ',', '') as float) < 200.00 and IsValidVL=1 THEN 1 + ELSE 0 + END + ELSE + CASE + WHEN [TestResult] in ('undetectable','NOT DETECTED','0 copies/ml','LDL','Less than Low Detectable Level') and IsValidVL=1 THEN 1 + ELSE 0 + END + END + ,IsPBFW + from Combine_PBFWListing_VLSupCheck + +), + +Combine_PBFWListing_VLSupCheck_Final As( + select SiteCode, + PatientPK + ,PatientPkHash + ,StartARTDate + ,CohortYearMonth + ,CohortYear + ,AgeAsOfDate + ,OrderedbyDate + ,ReportedbyDate + ,AsOfDate + ,TestName + ,TestResult + ,Emr + ,Project + ,EligibleVL + ,IsValidVL + ,VLSup + ,IsPBFW + from CombinedValidityCheck +) +INSERT INTO ndwh.dbo.FactViralLoad_Hist(PatientKey, + FacilityKey, + AgeGroupKey, + CohortYearMonth, + CohortYear, + StartARTDate, + AgeAsOfDate, + OrderedbyDate, + ReportedbyDate, + EligibleVL, + IsValidVL, + VLSup, + AsOfDate, + TestName, + TestResult, + Emr, + Project, + IsPBFW + ) + +SELECT Patient.PatientKey, + Facility.FacilityKey, + AgeGroup.AgeGroupKey, + CohortYearMonth, + CohortYear, + StartARTDate, + AgeAsOfDate, + OrderedbyDate, + ReportedbyDate, + EligibleVL, + IsValidVL, + VLSup, + AsOfDate, + TestName, + TestResult, + VLSupCheck.Emr, + VLSupCheck.Project , + ISnull(VLSupCheck.IsPBFW,0) +FROM Combine_PBFWListing_VLSupCheck_Final VLSupCheck +left join NDWH.dbo.DimPatient Patient + on VLSupCheck.SiteCode = Patient.SiteCode and VLSupCheck.PatientPkHash = Patient.PatientPKHash +Left join NDWH.dbo.DimFacility Facility + on VLSupCheck.SiteCode = Facility.MFLCode +left join [NDWH].[dbo].[DimAgeGroup] AgeGroup + on VLSupCheck.AgeAsOfDate = AgeGroup.Age + + +fetch next from cursor_AsOfDates into @as_of_date +end +drop table #months +close cursor_AsOfDates +deallocate cursor_AsOfDates + + + diff --git a/Scripts/REPORTING/HIVCaseSurveillance/Load_Cs_LinelistHistoricalViralLoad.sql b/Scripts/REPORTING/HIVCaseSurveillance/Load_Cs_LinelistHistoricalViralLoad.sql index a7202ad4..06f75cb1 100644 --- a/Scripts/REPORTING/HIVCaseSurveillance/Load_Cs_LinelistHistoricalViralLoad.sql +++ b/Scripts/REPORTING/HIVCaseSurveillance/Load_Cs_LinelistHistoricalViralLoad.sql @@ -10,12 +10,14 @@ BEGIN ,Patient.PatientPKHash ,Patient.Gender ,Patient.DOB + ,StartARTDate ,AsOfDate ,AgeAsOfDate ,[AgeGroup].DATIMAgeGroup ,YEAR(TRY_CAST(DateConfirmedHIVPositiveKey AS DATE)) As CohortYear ,TRY_CAST(DateConfirmedHIVPositiveKey AS DATE) As CohortYearMonth ,cast(DateConfirmedHIVPositiveKey as date) As OutcomeYearMonth + ,IsPBFW ,EligibleVL As VLEligibility ,IsValidVL As VLValidity ,VLSup As VLSuppression From 88bef266a965bc9c224f2a315285812cbb4ee388 Mon Sep 17 00:00:00 2001 From: Mugo Date: Fri, 2 Aug 2024 21:54:00 +0300 Subject: [PATCH 4/4] Added a comment disclaimer --- Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql b/Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql index 9f1cae17..a102d90f 100644 --- a/Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql +++ b/Scripts/NDWH/C&T FACT TABLES/FactHistoricalViralLoad.sql @@ -1,3 +1,7 @@ +/* +Created by : Dennis Mugo +Revised by : Nobert Mumo and Mary Wambui +*/ TRUNCATE TABLE ndwh.dbo.FactViralLoad_Hist; DECLARE @start_date DATE;