|
SQL запрос с транспонированием
|
|||
---|---|---|---|
#18+
Всем доброго времени суток! Есть таблица emp с числовыми полями U1, F1 и полем DT (дата), см скриншот. нужно составить SQL-запрос так, чтобы значения столбца DT для записей каждой из пар U1, F1 транспонировались бы в строку с динамическим добавлением полей DT (DT_1, DT_2 ... DT_N), в результате должна получиться таблица result как на скриншоте. пробовал смотреть в сторону Pivot, но пока не очень получается. Подскажите пожалуйста как такое написать! ... |
|||
:
Нравится:
Не нравится:
|
|||
11.01.2017, 18:46 |
|
SQL запрос с транспонированием
|
|||
---|---|---|---|
#18+
Miko_v, но это же максимум 255 полей ... |
|||
:
Нравится:
Не нравится:
|
|||
11.01.2017, 19:08 |
|
SQL запрос с транспонированием
|
|||
---|---|---|---|
#18+
Для начала воспользуйтесь поиском и найдите, как при группировке получить конкатенацию поля зля записей группы. Напишите запрос. Потом найдите, как из такого CSV-текста выделять группу с заданным номером. А также - как создать синтетическую таблицу чисел. Объединив это, поделите CSV-поле на отдельные куски и распихайте по полям. Но ещё лучше, если всей этой ерундой займётся клиент - ибо это всё нереляционно. ... |
|||
:
Нравится:
Не нравится:
|
|||
11.01.2017, 19:35 |
|
SQL запрос с транспонированием
|
|||
---|---|---|---|
#18+
Miko_v, два запроса и модуль U1F1dt_1dt_3dt_512505.01.201709.01.201712611.01.201732704.01.201732803.01.201732901.01.201702.01.201711.01.2017 ... |
|||
:
Нравится:
Не нравится:
|
|||
11.01.2017, 19:56 |
|
SQL запрос с транспонированием
|
|||
---|---|---|---|
#18+
Akina, спасибо большое за советы, буду думать ... |
|||
:
Нравится:
Не нравится:
|
|||
11.01.2017, 23:05 |
|
SQL запрос с транспонированием
|
|||
---|---|---|---|
#18+
ПЕНСИОНЕРКАMiko_v, два запроса и модуль U1F1dt_1dt_3dt_512505.01.201709.01.201712611.01.201732704.01.201732803.01.201732901.01.201702.01.201711.01.2017 очень элегантное решение, спасибо Вам больше! по-моему, это то что нужно! ... |
|||
:
Нравится:
Не нравится:
|
|||
11.01.2017, 23:07 |
|
SQL запрос с транспонированием
|
|||
---|---|---|---|
#18+
Miko_v, ещё такой вариант (одним запросом) Код: sql 1. 2. 3. 4. 5. 6.
Предполагается, что совокупность полей U1, F1, DT уникальна. Если это не так, то нужно таблицу emp пополнить полем типа счётчик (см. у ПЕНСИОНЕРКА поле Код) и несколько изменить в запросе условие для DCount. ... |
|||
:
Нравится:
Не нравится:
|
|||
12.01.2017, 10:33 |
|
SQL запрос с транспонированием
|
|||
---|---|---|---|
#18+
-Практикант-Miko_v, ещё такой вариант (одним запросом) Код: sql 1. 2. 3. 4. 5. 6.
Предполагается, что совокупность полей U1, F1, DT уникальна. Если это не так, то нужно таблицу emp пополнить полем типа счётчик (см. у ПЕНСИОНЕРКА поле Код) и несколько изменить в запросе условие для DCount. это наверное самое подходящее решение, спасибо Вам большое! ... |
|||
:
Нравится:
Не нравится:
|
|||
12.01.2017, 10:49 |
|
|
start [/forum/topic.php?fid=45&msg=39382954&tid=1612817]: |
0ms |
get settings: |
10ms |
get forum list: |
17ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
95ms |
get topic data: |
11ms |
get forum data: |
2ms |
get page messages: |
41ms |
get tp. blocked users: |
1ms |
others: | 14ms |
total: | 197ms |
0 / 0 |