|
Выборка из трех таблиц
|
|||
---|---|---|---|
#18+
Доброго времени суток! Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17.
где: periods.contract_id <-> contracts.rowid payments.contract_id <-> contracts.rowid Ноль или несколько записей в таблицах periods и payments могут соответствовать одной записи в таблице contracts. Требуется получить выборку из полей: contracts.rowid contracts.code contracts.first_name contracts.last_name min_date (наименьшее значение periods.date_from, где periods.contract_id = contracts.rowid) max_date (наибольшее значение periods.date_to, где periods.contract_id = contracts.rowid) sum_amount (суммарное значение periods.amount, где periods.contract_id = contracts.rowid) sum_payment (суммарное значение payments.amount, где payments.contract_id = contracts.rowid) Поля min_date, max_date, sum_amount, sum_payment должны быть равны нулю, если нет соответствующих записей в таблицах periods или payments. Заранее благодарю за помощь в написании запроса. ... |
|||
:
Нравится:
Не нравится:
|
|||
17.09.2014, 00:07 |
|
Выборка из трех таблиц
|
|||
---|---|---|---|
#18+
Дениска Рохлин, читать про OUTER JOIN-ы до полного просветления. заодно глянуть GROUP BY и derived table (inline view, select from select, etc.) ... |
|||
:
Нравится:
Не нравится:
|
|||
17.09.2014, 06:40 |
|
Выборка из трех таблиц
|
|||
---|---|---|---|
#18+
Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17.
Не уверен, что все делаю правильно и нет более рационального решения, но вроде бы работает. ... |
|||
:
Нравится:
Не нравится:
|
|||
17.09.2014, 18:43 |
|
|
start [/forum/topic.php?fid=54&fpage=11&tid=2008749]: |
0ms |
get settings: |
10ms |
get forum list: |
14ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
53ms |
get topic data: |
14ms |
get forum data: |
3ms |
get page messages: |
46ms |
get tp. blocked users: |
2ms |
others: | 265ms |
total: | 415ms |
0 / 0 |