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

start [/forum/topic.php?fid=45&mobile=1&tid=1612817]: |
0ms |
get settings: |
9ms |
get forum list: |
15ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
457ms |
get topic data: |
13ms |
get forum data: |
3ms |
get page messages: |
47ms |
get tp. blocked users: |
2ms |
| others: | 231ms |
| total: | 783ms |

| 0 / 0 |
