Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Можно ли так запивотить / 5 сообщений из 5, страница 1 из 1
26.08.2019, 11:12
    #39853676
Кнюпель
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Можно ли так запивотить
Можно—ли из вот этого

Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
DECLARE @t TABLE
(
  FieldName varchar(50), 
  PeriodId int,
  PeriodValue varchar(50)
)

insert into @t values('name1', 1, 'value1')
insert into @t values('name1', 2, 'value2')
insert into @t values('name1', 4, 'value3')
insert into @t values('name2', 1, 'value4')
insert into @t values('name3', 3, 'value5')

select * from @t



Получить вот это


Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
DECLARE @result TABLE
(
  FieldName varchar(50), 
  Period_1 varchar(50),
  Period_2 varchar(50),
  Period_3 varchar(50),
  Period_4 varchar(50)
)

insert into @result values('name1', 'value1', 'value2', null, 'value3')
insert into @result values('name2', 'value4', null, null, null)
insert into @result values('name3', null, null, 'value5', null)

select * from @result



Т.е. не просто развернуть, но и сгруппировать по FieldName?
...
Рейтинг: 0 / 0
26.08.2019, 11:20
    #39853681
Посетитель
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Можно ли так запивотить
КнюпельМожно—ли из вот этого

Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
DECLARE @t TABLE
(
  FieldName varchar(50), 
  PeriodId int,
  PeriodValue varchar(50)
)

insert into @t values('name1', 1, 'value1')
insert into @t values('name1', 2, 'value2')
insert into @t values('name1', 4, 'value3')
insert into @t values('name2', 1, 'value4')
insert into @t values('name3', 3, 'value5')

select * from @t




Получить вот это


Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
DECLARE @result TABLE
(
  FieldName varchar(50), 
  Period_1 varchar(50),
  Period_2 varchar(50),
  Period_3 varchar(50),
  Period_4 varchar(50)
)

insert into @result values('name1', 'value1', 'value2', null, 'value3')
insert into @result values('name2', 'value4', null, null, null)
insert into @result values('name3', null, null, 'value5', null)

select * from @result




Т.е. не просто развернуть, но и сгруппировать по FieldName?
да
...
Рейтинг: 0 / 0
26.08.2019, 11:22
    #39853683
msLex
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Можно ли так запивотить
Кнюпель
Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
DECLARE @t TABLE
(
  FieldName varchar(50), 
  PeriodId int,
  PeriodValue varchar(50)
)

insert into @t values('name1', 1, 'value1')
insert into @t values('name1', 2, 'value2')
insert into @t values('name1', 4, 'value3')
insert into @t values('name2', 1, 'value4')
insert into @t values('name3', 3, 'value5')

select * from @t



https://docs.microsoft.com/ru-ru/sql/t-sql/queries/from-using-pivot-and-unpivot?view=sql-server-2017

Complex PIVOT Example
...
Рейтинг: 0 / 0
26.08.2019, 16:46
    #39853802
hewlett
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Можно ли так запивотить
Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
DECLARE @t TABLE
(
  FieldName varchar(50), 
  PeriodId int,
  PeriodValue varchar(50)
)

insert into @t values('name1', 1, 'value1')
insert into @t values('name1', 2, 'value2')
insert into @t values('name1', 4, 'value3')
insert into @t values('name2', 1, 'value4')
insert into @t values('name3', 3, 'value5')

select * from @t;


select * from @t p
pivot
(max(PeriodValue)
for PeriodId in ([1],[2],[3],[4])
) as pvt
...
Рейтинг: 0 / 0
27.08.2019, 09:12
    #39854009
Кнюпель
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Можно ли так запивотить
hewlett
Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
DECLARE @t TABLE
(
  FieldName varchar(50), 
  PeriodId int,
  PeriodValue varchar(50)
)

insert into @t values('name1', 1, 'value1')
insert into @t values('name1', 2, 'value2')
insert into @t values('name1', 4, 'value3')
insert into @t values('name2', 1, 'value4')
insert into @t values('name3', 3, 'value5')

select * from @t;


select * from @t p
pivot
(max(PeriodValue)
for PeriodId in ([1],[2],[3],[4])
) as pvt


спасибо!
...
Рейтинг: 0 / 0
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Можно ли так запивотить / 5 сообщений из 5, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]