
Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
|
07.03.2017, 14:31
|
|||
|---|---|---|---|
агрегация в подгруппах (start_of_group) |
|||
|
#18+
Уважаемые, помогите пожалуйста дописать запрос связанный с группировками строк. имеется следующий набор данных Код: plsql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. Требуется вычислить три колонки - cash_sum, ordering, cash_long Код: plsql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. cash_sum - это накапливающая сумма колонки cash в тех последовательных строках по dt где marker=0, если marker=1 то начиная с этой строки сумма накапливается сначала. ordering - нумерация строк отсортированных по dt. номер 1 присваивается строке в которой marker=1 или первой строке в группе с marker=0 (у нее priznak=Y) cash_long - в рамках того же самого окна (где marker=0 протянуть сумму cash из 1й строки группы (priznak=Y)) Полагаю что поле marker нужно сопоставить с полей start_of_group? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
07.03.2017, 14:59
|
|||
|---|---|---|---|
агрегация в подгруппах (start_of_group) |
|||
|
#18+
(o-O), Поле marker я ввел сам для возможности агрегации по окнам. Но возможно я его не правильно заполняю. Сейчас я решил ставить в нем 1 там где нет cash и там где priznak=Y. По этой логике в исходном наборенаборе у 4янвсря должна быть 1. Код: plsql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|

start [/forum/topic.php?fid=52&mobile=1&tid=1886321]: |
0ms |
get settings: |
7ms |
get forum list: |
10ms |
check forum access: |
2ms |
check topic access: |
2ms |
track hit: |
152ms |
get topic data: |
10ms |
get forum data: |
2ms |
get page messages: |
38ms |
get tp. blocked users: |
1ms |
| others: | 197ms |
| total: | 421ms |

| 0 / 0 |
