Вставить и обновить курсор в SQL Server - PullRequest
0 голосов
/ 10 января 2019

У меня есть таблица, показанная ниже

DateRange
10/1
11/1
12/1

Я перебираю эту таблицу с помощью курсора и пытаюсь заполнить временную таблицу

Create table #BidStatusCalculation1
(    
  Code nvarchar(max), 
  Data int  
)
Declare @monthStart varchar(20)   
DECLARE cur CURSOR FOR SELECT DateRange FROM @dateRange
OPEN cur
FETCH NEXT FROM cur INTO @monthStart
WHILE @@FETCH_STATUS = 0 BEGIN

Insert into #BidStatusCalculation1
    select 'SL Payroll',Count(*) from DashboardData
    where DataType = 'Bid'
    and CONVERT(NVARCHAR, CreatedDate, 105) = convert(datetime, 
                                             (@monthStart+'/'+@RequestYear))  

FETCH NEXT FROM cur INTO @monthStart
END
CLOSE cur    
DEALLOCATE cur

Это дает мне результат, как показано ниже

Code          Data
SL Payroll    22
SL Payroll    33
SL Payroll    43

Я хочу изменить таблицу, поэтому я получаю только одну строку, как

Code         Data1   Data2   Data3
SL Payroll   22       33      43

Может кто-нибудь сказать мне, что может быть хорошим подходом - сначала вставить данные в таблицу в первом цикле, а затем обновить их. Я могу поставить переменную для подсчета итерации цикла, а затем написать отдельную вставку и обновление, но мне было интересно, есть ли лучший способ.

Спасибо

1 Ответ

0 голосов
/ 10 января 2019

Использование PIVOT как

SELECT Code,
       [22] Data1,
       [33] Data2,
       [43] Data3
FROM
    (
      SELECT *
      FROM T
    ) TBL
    PIVOT
    (
      MAX(Data) FOR Data IN([22],[33],[43])
    ) PVT

Демо

Для динамического поворота

CREATE TABLE T
(
  Code VARCHAR(45),
  Data INT
);

INSERT INTO T VALUES
('SL Payroll',    22),
('SL Payroll',    33),
('SL Payroll',    43);

DECLARE @IN VARCHAR(MAX) = '',
        @Cols VARCHAR(MAX) = '';

SELECT @IN = @IN + ',' + QUOTENAME(Data),
       @Cols = @Cols + ',' + QUOTENAME(Data) + ' AS Data'+
               CAST(ROW_NUMBER()OVER(ORDER BY (SELECT NULL)) AS VARCHAR)
FROM T;

SELECT @IN = STUFF(@IN, 1, 1, ''), @Cols = STUFF(@Cols, 1, 1, '');

DECLARE @SQL NVARCHAR(MAX) = N'SELECT Code, ' +
                               @Cols+
                               ' FROM (SELECT * FROM T) TBL PIVOT (MAX(Data) FOR Data IN('+
                               @IN+
                               ')) PVT';
     EXECUTE sp_executesql @SQL;

Демо

...