|
|
|
Объединение выборок, ограниченных по числу строк.
|
|||
|---|---|---|---|
|
#18+
Прошу прощения за кросс-постинг, не сразу догадался спросить здесь. :( ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Мне нужно выбрать все строки из таблички A, начиная с заданной даты в заданном количество. Количество и начальная дата хранятся в табличке B. + Скрипт Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. 24. 25. 26. 27. 28. В итоге имеем: Табличка A: IDRELEASE_DATE101.01.2009201.02.2009301.01.2010402.01.2010501.02.2010615.02.2010720.02.2010825.02.2010901.03.20101005.03.20101106.04.20101207.07.20101308.08.20101409.09.2010 Табличка B: IDFROM_RELEASEQUANTITY101.01.20102213.02.20103301.03.201011 Для каждой строки из B нужно получить множество строк из A, отсортированных по RELEASE_DATE, начиная со строки, значение RELEASE_DATE в которой не меньше чем значение A.FROM_DATE и в количество, не большем чем A.QUANTITY. Т.е., для строки таблички В: IDFROM_RELEASEQUANTITY101.01.20102 ...должны быть выбраны след. строки таблички А: IDRELEASE_DATE301.01.2010402.01.2010 Для строки IDFROM_RELEASEQUANTITY213.02.20103 ...должны быть выбраны след. строки таблички А: IDRELEASE_DATE615.02.2010720.02.2010825.02.2010 А для строки IDFROM_RELEASEQUANTITY301.03.201011 ...должны быть выбраны след. строки таблички А: IDRELEASE_DATE901.03.20101005.03.20101106.04.20101207.07.20101308.08.20101409.09.2010 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Итоговая выборка из А должна быть такой: IDRELEASE_DATE301.01.2010402.01.2010615.02.2010720.02.2010825.02.2010901.03.20101005.03.20101106.04.20101207.07.20101308.08.20101409.09.2010 ...т.е., сумма всех выборок. C итоговой выборкой я бы хотел работать дальше - выбирать min/max и т.д.... Можно, конечно, написать отдельную ХП, но не хотелось бы: результат нужен в другой ХП... ...может быть, здесь CTE как - нибудь прикрутить? Спасибо. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ СУБД: FireBird 2.5 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 09.03.2010, 20:42 |
|
||
|
Объединение выборок, ограниченных по числу строк.
|
|||
|---|---|---|---|
|
#18+
Всем спасибо. Решение от Таблоида: Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 09.03.2010, 21:34 |
|
||
|
|

start [/forum/topic.php?fid=32&gotonew=1&tid=1542813]: |
0ms |
get settings: |
9ms |
get forum list: |
15ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
184ms |
get topic data: |
8ms |
get first new msg: |
6ms |
get forum data: |
3ms |
get page messages: |
30ms |
get tp. blocked users: |
1ms |
| others: | 250ms |
| total: | 514ms |

| 0 / 0 |
