Что не так с этим запросом SQL? - PullRequest
1 голос
/ 10 февраля 2010

Следующий запрос возвращает «Ошибка ORA-00904: SATIS: неверный идентификатор». Когда я удаляю строку HAVING satis > 0, это работает. Что мне делать?

SELECT donem, bolge_adi, sehir_tasra "1=Ş, 2=T", 
       COUNT(DISTINCT mekankodu) "M.SAYISI",
       SUM(b2b_dagitim + b2b_transfer - b2b_iade) satis
FROM mps_view2
WHERE donem IN ('200612','200712','200812','200912')
AND (ob IS NOT NULL OR b2b_ob IS NOT NULL)
GROUP BY donem, bolge_adi, sehir_tasra
HAVING satis > 0
ORDER BY donem, bolge_adi, sehir_tasra

Ответы [ 3 ]

7 голосов
/ 10 февраля 2010

Нельзя использовать псевдоним в условиях (имеющих раздел вашего запроса)

попробуйте это:

SELECT donem, bolge_adi, sehir_tasra "1=Ş, 2=T", 
   COUNT(DISTINCT mekankodu) "M.SAYISI",
   SUM(b2b_dagitim + b2b_transfer - b2b_iade) satis
FROM mps_view2
WHERE donem IN ('200612','200712','200812','200912')
      AND (ob IS NOT NULL OR b2b_ob IS NOT NULL)
GROUP BY donem, bolge_adi, sehir_tasra
HAVING SUM(b2b_dagitim + b2b_transfer - b2b_iade) > 0
ORDER BY donem, bolge_adi, sehir_tasra
4 голосов
/ 10 февраля 2010

Отсюда:

http://download.oracle.com/docs/cd/B19306_01/server.102/b14200/statements_10002.htm

Псевдоним может быть использован в order_by_clause но не другие пункты в запросе.

1 голос
/ 10 февраля 2010

Вам нужно изменить его на

SELECT donem, bolge_adi, sehir_tasra "1=Ş, 2=T",  
       COUNT(DISTINCT mekankodu) "M.SAYISI", 
       SUM(b2b_dagitim + b2b_transfer - b2b_iade) satis 
FROM mps_view2 
WHERE donem IN ('200612','200712','200812','200912') 
AND (ob IS NOT NULL OR b2b_ob IS NOT NULL) 
GROUP BY donem, bolge_adi, sehir_tasra 
HAVING SUM(b2b_dagitim + b2b_transfer - b2b_iade) > 0
ORDER BY donem, bolge_adi, sehir_tasra 

Вы не можете использовать псевдоним в предложении HAVING.

...