Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/18: Рейтинг темы: голосов - 18, средняя оценка - 4.56
0 / 0 / 0
Регистрация: 24.04.2013
Сообщений: 4

Запрос для преобразования таблицы в шахматку

15.08.2013, 13:53. Показов 3925. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день,

Есть таблица с полями Дата, Наименование, Кол-во
Необходимо развернуть таблицу таким образом чтобы в области строк были Наименования, в области Столбцов - даты, а в области данных - кол-во. Подскажите как такое можно реализовать
 
1 2 5 6 7
Анальгин 8
Аспирин 1 1
Бинт нестерильный 42 27 32 26 42
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.08.2013, 13:53
Ответы с готовыми решениями:

Запрос для таблицы
Есть таблица в которой две колонки: сотрудник и его должность.Таблица `employers` employee post … … Надо составить...

Запрос для сводной таблицы
Доброго времени суток. Искал на этой категории ответ на свой вопрос,но безуспешно(хотя,наверное, я не правильно искал) Помогите...

WPF: создать шахматку
Подскажите как можно реализовать шахматку для гостиницы (как на картинке)

6
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
15.08.2013, 14:57
namec1c2c5c6c7
Анальгин 8   
Аспирин1   1
Бинт нестерильный4227322642
T-SQL
1
2
3
4
5
6
7
8
;with SourceData as (select * from (values
('Анальгин','','8','','',''),
('Аспирин','1','','','','1'),
('Бинт нестерильный','42','27','32','26','42')
    )temp_SourceData(name,c1,c2,c5,c6,c7))
select * from SourceData
unpivot(val for col in (c1,c2,c5,c6,c7))u
pivot(max(val)for name in ([Анальгин],[Аспирин],[Бинт нестерильный]))p
colАнальгинАспиринБинт нестерильный
c1 142
c28 27
c5  32
c6  26
c7 142
0
0 / 0 / 0
Регистрация: 24.04.2013
Сообщений: 4
15.08.2013, 15:34  [ТС]
Цитата Сообщение от cygapb-007 Посмотреть сообщение
namec1c2c5c6c7
Анальгин 8   
Аспирин1   1
Бинт нестерильный4227322642
T-SQL
1
2
3
4
5
6
7
8
;with SourceData as (select * from (values
('Анальгин','','8','','',''),
('Аспирин','1','','','','1'),
('Бинт нестерильный','42','27','32','26','42')
    )temp_SourceData(name,c1,c2,c5,c6,c7))
select * from SourceData
unpivot(val for col in (c1,c2,c5,c6,c7))u
pivot(max(val)for name in ([Анальгин],[Аспирин],[Бинт нестерильный]))p
colАнальгинАспиринБинт нестерильный
c1 142
c28 27
c5  32
c6  26
c7 142
я видимо плохо объяснила) изначально таблица выглядит так:

1 Анальгин 6
1 Аспирин 1
1 Бинт 3
2 Бинт 1
3 Анальгин 2

в результате необходимо получить шахматку
1 2 3
Анальгин 6 2
Аспирин 1
Бинт 3 1
0
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
15.08.2013, 16:58
LilkaS, удалите строку 8 - получите вашу исходную таблицу
восстановите - получите то, что требуется
0
0 / 0 / 0
Регистрация: 24.04.2013
Сообщений: 4
16.08.2013, 09:17  [ТС]
Цитата Сообщение от cygapb-007 Посмотреть сообщение
LilkaS, удалите строку 8 - получите вашу исходную таблицу
восстановите - получите то, что требуется
а если у меня в Наименованиях 1000 строк мне их все перечислять что ли?
0
1313 / 945 / 144
Регистрация: 17.01.2013
Сообщений: 2,348
16.08.2013, 09:31
а вы хотите получить 1000 колонок?

вы же хотите даты получить - вот и перечисляйте нужные даты. Про [ ] не забудьте только ))
0
 Аватар для Devil_FoX
168 / 142 / 1
Регистрация: 01.04.2010
Сообщений: 474
16.08.2013, 10:14
Цитата Сообщение от LilkaS Посмотреть сообщение
а если у меня в Наименованиях 1000 строк мне их все перечислять что ли?
если я правильно понят что у вас таблица вида:

C1NameKol
1Анальгин6
1Аспирин1
1Бинт3
2Бинт1
3Анальгин2




T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
    DECLARE @R VARCHAR(5000), @ST VARCHAR(5000)
    SELECT @R = ISNULL(@R,'')+ CASE WHEN @R IS NULL THEN '' ELSE ', ' END + '['+cast (filid AS varchar(100))+']'
    FROM (  select distinct
                C1
            from Tabl) a
 
SET @ST = '
select
    ppp.*
from Tabl a
pivot(
    sum(Kol)
    for C1 in ('+ @R +')
    ) as ppp    '
EXEC (@ST)
Писал в слепую, могут быть где-то ошибки
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.08.2013, 10:14
Помогаю со студенческими работами здесь

Запрос для получения временной таблицы
При построении запроса столкнулся с проблемой, выполняется только первый запрос из строки, остальные игнорируются. Что нужно использовать...

Простой запрос для одной таблицы
Всего лишь одна таблица. ID, Команда1, Счёт1, Команда2, Счёт2. Мне необходимо найти общее количество забитых мячей для каждой команды....

Запрос на вычитание для подчиненной таблицы
Привет, уважаемые гуру БД! У меня случилась такая задачка: есть таблица "Заказано" и подчиненная таблица "Товары", нужно...

SQL запрос для заполнения таблицы
Помогите пожалуйста кто сможет. Как написать SQL запрос для заполнения таблицы. Я таблицу создал и начал заполнять не используя запроса(((,...

Составить запрос insert добавление для таблицы с ID
Здравствуйте, имеется таблица, которая содержит ID других таблиц(структуру базы смотреть во вложениях), хочу добавить туда новую запись, не...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru