CREATE procedure [dbo].[USP_CRT_Agg_1Minute_OLD] @StartDate datetime = NULL, @1MinFromStartDate Bit = 0 AS SET NOCOUNT ON declare @EndDate datetime, @RowsAffected int, @RowsToProcess int SET @RowsAffected = 0 SET @EndDate = dateadd(millisecond, -datepart(millisecond, getdate()) -datepart(second, getdate())*1000 - 3, getdate()) IF @StartDate is NULL Begin --set @StartDate = DateAdd(minute,-1,Cast(convert(char(16), getdate(),121) as datetime)) --select @StartDate = isnull(CRTT_LastRun, DateAdd(minute,-1,Cast(convert(char(16), getdate(),121) as datetime))) from CRT_Tasks with (nolock) where CRTT_TableName = 'CRT_Data_1Minute' select @StartDate = Max([CRTD_Period]) from [dbo].[CRT_Data_1Minute] select @StartDate = isnull(@StartDate, DateAdd(minute,-1,Cast(convert(char(16), getdate(),121) as datetime))) --- select isnull(CRTT_LastRun, DateAdd(minute,-1,Cast(convert(char(16), getdate(),121) as datetime))) from CRT_Tasks with (nolock) where CRTT_TableName = 'CRT_Data_1Minute' End ELSE Begin set @StartDate = Cast(convert(char(16), @StartDate,121) as datetime) IF @1MinFromStartDate = 1 Begin Set @EndDate = DateAdd(minute, 1 , @StartDate) set @EndDate = dateadd(millisecond, -datepart(millisecond, @EndDate) -datepart(second, @EndDate)*1000 - 3, @EndDate) End End --select @StartDate StartDate , @EndDate EndDate if @StartDate >= @EndDate Begin print 'Start Date is not greater than End Date' return End IF Exists (select 1 from CRT_Data_1Minute where [CRTD_Period] > @StartDate) Begin select 'Period Already Exists' as [Reason] return End ;with c2 as ( select [PairSymbol], convert(varchar(16),[BidReceivedDate],121) as [minute], min([Bid]) as Bid_Low , --- Low max([Bid]) as Bid_High, --- High min([Mid]) as Mid_Low , --- Low max([Mid]) as Mid_High, --- High Count([Id]) as Cnt from YB_Quotes.dbo.[SpotRatesHistory] with (nolock) where 1=1 and [BidReceivedDate] between @StartDate and @EndDate --and [PairSymbol] = 'EURUSD' group by convert(varchar(16), [BidReceivedDate] ,121) ,[PairSymbol] ), c3 as ( select [PairSymbol], convert(varchar(16),[BidReceivedDate] ,121) as [minute], [BidReceivedDate] AS [DateQuote], [Bid] AS Bid_Val, [Mid] AS Mid_Val, ROW_NUMBER() over (partition by [PairSymbol],convert(varchar(16),[BidReceivedDate] ,121) order by [BidReceivedDate] ) as Bid_start, ROW_NUMBER() over (partition by [PairSymbol],convert(varchar(16),[BidReceivedDate] ,121) order by [BidReceivedDate] desc) as Bid_end from YB_Quotes.dbo.[SpotRatesHistory] with (nolock) where 1=1 and [BidReceivedDate] between @StartDate and @EndDate --and [PairSymbol] = 'EURUSD' ) INSERT INTO [dbo].[CRT_Data_1Minute] ([CRTD_Period] ,[CRTD_FirstQuote] ,[CRTD_LastQuote] ,[CRTD_PairSymbol] ,[CRTD_BidOpeningValue] ,[CRTD_BidClosingValue] ,[CRTD_BidLowValue] ,[CRTD_BidHighValue] ,[CRTD_MidOpeningValue] ,[CRTD_MidClosingValue] ,[CRTD_MidLowValue] ,[CRTD_MidHighValue] ,[CRTD_DateIn] ,[CRTD_Rows]) select c2.[minute] [CRTD_Period], c3.[DateQuote] [CRTD_FirstQuote], c3_Bid.[DateQuote] [CRTD_LastQuote], c2.PairSymbol, c3.Bid_Val as Bid_OpenValue, IsNull(c3_Bid.Bid_Val,0) as Bid_CloseValue, Bid_Low, Bid_High, IsNull(c3.Mid_Val,0) as Mid_OpenValue, IsNull(c3_Bid.Mid_Val,0) as Mid_CloseValue, Mid_Low, Mid_High, GetDate() As Date_Inserted, c2.Cnt from c2 Inner join c3 on c2.[PairSymbol] = c3.[PairSymbol] and c2.[minute] = c3.[minute] and Bid_start =1 Inner join c3 as c3_Bid on c2.[PairSymbol] = c3_Bid.[PairSymbol] and c2.[minute] = c3_Bid.[minute] and c3_Bid.Bid_end =1 Where 1=1 and Not Exists (select 1 from [CRT_Data_1Minute] XX with (nolock) where XX.[CRTD_PairSymbol] = c2.PairSymbol collate SQL_Latin1_General_CP1_CI_AS and XX.[CRTD_Period] = c2.[minute]) order by 1,4 select @RowsAffected = @@RowCount update CRT_Tasks set CRTT_LastRun = @EndDate, CRTT_LastRowCount = @RowsAffected, CRTT_LastModifiedDate = GetDate() where CRTT_TableName = 'CRT_Data_1Minute' --select @RowsToProcess RowsToProcess, @RowsAffected RowsAffected --select * from CRT_Tasks where CRTT_ID = 1 print Cast (@RowsAffected as varchar(10)) + ' Rows Processed' --- select top 100 * from [dbo].[CRT_Data_1Minute] order by 1 desc --- select * from [CRT_Tasks]