Необходимо вменять недостающие данные из малонаселенной таблицы - PullRequest
2 голосов
/ 21 июня 2019

Я пытаюсь заполнить таблицу отчетов #temp из существующей разреженной таблицы двумя ключевыми элементами - датами и ценами, основанными на диапазоне дат и ценах по мере их изменения.Вот данные, которые существуют в таблице изменения цен:

enter image description here

Диапазон дат для отчета 2 дня назад по скользящему 7-дневному циклу будет включать6/12 - 6/19.2 строки в таблице имеют старую цену и старое отклонение цены от 6/7 вне диапазона для этого отчета, однако цена и отклонение необходимы для того, чтобы перезаписать их в столбце CashPrice для всех ключей даты с 20190612 по 20190618.С 6/19 новое изменение / отклонение цены.В этом ключе даты новые значения цены / отклонения должны измениться.

Данные настройки, необходимые для отчетности, должны выглядеть следующим образом:

enter image description here

Вот код для построения данных выборки:

-- T-SQL script to build the sampling tables

-- use for date-related cross-join later
if object_id( N'tempdb..#Numbers', N'U' ) is not null 
drop table #Numbers;

create table #Numbers(
   n int
 );

insert #Numbers( n ) values( 0 ), ( 1 ), ( 2 ), ( 3 ), ( 4 ), ( 5 ), ( 6 ), 
( 7 ), ( 8 ), ( 9 ), ( 10 ) 


-- select * from #Numbers;

-- creating existing sparse price data
if object_id( N'tempdb..#dt', N'U' ) is not null 
 drop table #dt;

create table #dt(
  StoreNumber int
  , City char( 3 )
  , State char( 2 )
  , Type char( 1 )
  , ProductKey int
  , DateKey int
  , CashPrice money
  , DateLastPriceChange datetime
  , CashPriceVar money
 )

 insert #dt values
    ( 1, 'OKC', 'OK', 'D', 144, 20190607, 2.799, '2019-06-07 11:37', -0.1 )
  , ( 1, 'OKC', 'OK', 'D', 144, 20190619, 2.699, '2019-06-19 10:40', -0.1 )

-- select * from #dt;

-- creaing temporary working table for reporting
if object_id( N'tempdb..#tt', N'U' ) is not null 
  drop table #tt;

create table #tt(
  StoreNumber int
, City char( 3 )
, State char( 2 )
, Type char( 1 )
, ProductKey int
, DateKey int
-- a couple of extra columns here
, DateKeyDate date
, DataDateKey int
, CashPrice money
, DateLastPriceChange datetime
, CashPriceVar money
)

-- dub in the start date for the report
declare @StartDateKey date = '2019-06-12'

-- populate the temporary working table
insert #tt( StoreNumber, ProductKey, DateKeyDate )
 select distinct
   dt.StoreNumber
 , dt.ProductKey
 , dateadd( day, n.n, @StartDateKey )
 from #dt dt
  cross join #Numbers n
 where
  n.n <= 7

-- select * from #tt

-- change the added datekeydate to datekey format
update #tt
set DateKey = year( DateKeyDate ) * 10000 + month( DateKeyDate ) * 100 + 
    day( DateKeyDate )

Вот код, над которым я работал, который хромает.Он не идеален и во многих случаях сопоставляется с полным набором данных, он отфильтровывает даты, с которыми я перекрестно соединился, так что я остаюсь без вмененных данных - показывая только оригинальные известные изменения цены.Пожалуйста, сообщите.

select 
dd.StoreNumber
, dto.City
, dto.State
, dto.Type
, dd.ProductKey
, dd.DateKey
, dto.CashPrice
, dto.DateLastPriceChange
, dto.CashPriceVar
from (
 select 
    tt.StoreNumber
    , tt.ProductKey
    , tt.DateKey
    , max( dt.DateKey ) MaxDateKey
 from #tt tt
  inner join #dt dt
    on dt.StoreNumber = tt.StoreNumber
    and dt.ProductKey = tt.ProductKey
    and dt.DateKey <= tt.DateKey
 group by
    tt.StoreNumber
    , tt.ProductKey
    , tt.DateKey
) dd
inner join #dt dto
    on dto.StoreNumber = dd.StoreNumber
    and dto.ProductKey = dd.ProductKey
    and dto.DateKey = dd.MaxDateKey;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...