2015-02-11 4 views
0

Я искал в других вопросах, но я действительно не понимаю, как получить правильную сумму, а не декартовой продукт.Декартовы продукты SQL

У меня есть следующая таблица:

EGAIT6 EGACAM  EGVONO ACC 
2477717 -1443,87 41300015 2995 
2477717 -2424,75 41300021 2995 
2477717 -26630,16 41300022 2995 
2477717 22652,96 41563318 2995 
2477717 14513,12 41566334 2995 
2477717 7703,08 41566335 2995 
2477717 1443,87 41566336 2995 
2477717 2482,70 41566338 2995 
2477717 1124,84 41566339 2995 
2477717 4610,99 41566337 2995 
2477717 393,45 41571055 2995 
2477717 393,45 41571056 2995 
2477717 344,04 41574437 2995 
2477717 344,04 41574438 2995 
2477717 344,04 41584940 2995 
2477717 344,04 41584941 2995 
2477717 225,70 41689722 2995 
2477717 1814,75 41726904 2995 
2477717 1814,75 41726905 2995 

Это мой запрос:

select 
    a.egait6, 
    sum(a.egacam), 
    a.egvono, 
    max(a.egvtxt), 
    max(a.egacdt) 
from m3prd.fgledg a 
inner join m3prd.fgledg b 
    on a.egait6 = b.egait6 
where a.egcono=001 
    and a.egdivi='012' 
    and a.egait1='2995' 
    and a.egait6='2477717' 
group by a.egait6, a.egvono 
having sum(a.egacam)<>0 

я получаю следующий результат:

EGAIT6  EGACAM EGVONO 
2477717 6 880,80 41574437 
2477717 49 654,00 41566338 
2477717 6 880,80 41584940 
2477717 290 262,40 41566334 
2477717 36 295,00 41726905 
2477717 92 219,80 41566337 
2477717 -532 603,20 41300022 
2477717 154 061,60 41566335 
2477717 7 869,00 41571056 
2477717 6 880,80 41574438 
2477717 22 496,80 41566339 
2477717 36 295,00 41726904 
2477717 -48 495,00 41300021 
2477717 4 514,00 41689722 
2477717 453 059,20 41563318 
2477717 6 880,80 41584941 
2477717 -28 877,40 41300015 
2477717 7 869,00 41571055 
2477717 28 877,40 41566336 

Как получить мой запрос, чтобы вернуться правильная сумма в соответствии с моим столом, а не декартовой продукцией?

Правильное количество, ожидаемая стоимость в сумме составляет:

EGACAM 
- 1 443,87 
- 2 424,75 
- 26 630,16 
22 652,96 
14 513,12 
7 703,08 
1 443,87 
2 482,70 
1 124,84 
4 610,99 
393,45 
393,45 
344,04 
344,04 
344,04 
344,04 
225,70 
1 814,75 
1 814,75 

Я mamking в автообъединение becaus реальной таблицы Я ищу в России имеет больше и различные значения в обоих EGAIT6 и EGVONO. Поэтому я не могу удалить эту часть запроса. Я просто хочу знать, как избежать получения декартового продукта в результате.

+1

Какую сумму вы ожидаете получить? –

+0

Что такое «правильная сумма»? Вы не только не говорите это явно, но и ваши имена полей затрудняют это. – pyon

+0

Вы присоединяетесь к таблице для себя, используя то же самое поле в «обеих» таблицах. почему бы это не сделать? –

ответ

-1

удалить эти строки:

inner join m3prd.fgledg b 
on a.egait6 = b.egait6 

Я не вижу каких-либо использовать для создания объединения на одной и той же таблицы ....