|
|
|
SQL запрос с транспонированием
|
|||
|---|---|---|---|
|
#18+
Всем доброго времени суток! Есть таблица emp с числовыми полями U1, F1 и полем DT (дата), см скриншот. нужно составить SQL-запрос так, чтобы значения столбца DT для записей каждой из пар U1, F1 транспонировались бы в строку с динамическим добавлением полей DT (DT_1, DT_2 ... DT_N), в результате должна получиться таблица result как на скриншоте. пробовал смотреть в сторону Pivot, но пока не очень получается. Подскажите пожалуйста как такое написать! ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 11.01.2017, 18:46:02 |
|
||
|
SQL запрос с транспонированием
|
|||
|---|---|---|---|
|
#18+
Miko_v, но это же максимум 255 полей ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 11.01.2017, 19:08:23 |
|
||
|
SQL запрос с транспонированием
|
|||
|---|---|---|---|
|
#18+
Для начала воспользуйтесь поиском и найдите, как при группировке получить конкатенацию поля зля записей группы. Напишите запрос. Потом найдите, как из такого CSV-текста выделять группу с заданным номером. А также - как создать синтетическую таблицу чисел. Объединив это, поделите CSV-поле на отдельные куски и распихайте по полям. Но ещё лучше, если всей этой ерундой займётся клиент - ибо это всё нереляционно. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 11.01.2017, 19:35:30 |
|
||
|
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:51 |
|
||
|
SQL запрос с транспонированием
|
|||
|---|---|---|---|
|
#18+
Akina, спасибо большое за советы, буду думать ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 11.01.2017, 23:05:33 |
|
||
|
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:37 |
|
||
|
SQL запрос с транспонированием
|
|||
|---|---|---|---|
|
#18+
Miko_v, ещё такой вариант (одним запросом) Код: sql 1. 2. 3. 4. 5. 6. Предполагается, что совокупность полей U1, F1, DT уникальна. Если это не так, то нужно таблицу emp пополнить полем типа счётчик (см. у ПЕНСИОНЕРКА поле Код) и несколько изменить в запросе условие для DCount. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 12.01.2017, 10:33:01 |
|
||
|
SQL запрос с транспонированием
|
|||
|---|---|---|---|
|
#18+
-Практикант-Miko_v, ещё такой вариант (одним запросом) Код: sql 1. 2. 3. 4. 5. 6. Предполагается, что совокупность полей U1, F1, DT уникальна. Если это не так, то нужно таблицу emp пополнить полем типа счётчик (см. у ПЕНСИОНЕРКА поле Код) и несколько изменить в запросе условие для DCount. это наверное самое подходящее решение, спасибо Вам большое! ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 12.01.2017, 10:49:59 |
|
||
|
|

start [/forum/topic.php?fid=45&fpage=85&tid=1612817]: |
0ms |
get settings: |
10ms |
get forum list: |
16ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
31ms |
get topic data: |
8ms |
get forum data: |
2ms |
get page messages: |
36ms |
get tp. blocked users: |
2ms |
| others: | 243ms |
| total: | 354ms |

| 0 / 0 |
