Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2008.10.12;
Скачать: CL | DM;

Вниз

Запрос   Найти похожие ветки 

 
Александр Иванов ©   (2008-04-01 15:37) [0]

Не пойму в чем дело. Вчера отладил запрос. Сегодня внес небольшие изменения и он перестал работать. Изменения откатил, но ситуация не измнилась. В таблице PartnerCodes есть записи, остальные таблицы пустые. Ожидаю получить список записей из этой таблицы и нули в суммах и количестве, однако получаю пустой набор значений. Если убрать условия, то набор возвражается правильный, но напомню, что таблицы пустые.

SELECT PartnerCodes.ID, PartnerCodes.Name, COUNT(BannerRequests.ID) AS Requests, COUNT(BannerTours.ID) AS Tours,
Sum(IsNull(Payments.Amount, 0)) AS Amount, COUNT(BannerClicks.ID) AS Clicks
FROM PartnerCodes
LEFT OUTER JOIN BannerClicks ON PartnerCodes.ID = BannerClicks.PartnerCodeID
LEFT OUTER JOIN BannerTours ON PartnerCodes.ID = BannerTours.PartnerCodeID
LEFT OUTER JOIN BannerRequests ON PartnerCodes.ID = BannerRequests.PartnerCodeID
LEFT OUTER JOIN Payments ON PartnerCodes.ID = Payments.PartnerCodeID
WHERE PartnerCodes.UserID = @ID AND BannerClicks.ClickDate >= @DateFrom AND BannerClicks.ClickDate <= @DateTo
AND BannerRequests.RequestDate >= @DateFrom AND BannerRequests.RequestDate <= @DateTo
AND Payments.Amount > 0 AND BannerTours.TourDate >= @DateFrom AND BannerTours.TourDate < @DateTo
AND Payments.PaymentDate <= @DateTo AND Payments.PaymentDate >= @DateFrom
GROUP BY PartnerCodes.ID, PartnerCodes.Name


 
Александр Иванов ©   (2008-04-01 15:38) [1]

Да, забыл упомянуть, что это MS SQL 2005


 
ANB   (2008-04-01 15:52) [2]

1)

> WHERE PartnerCodes.UserID = @ID

Вот этот кусочек проверить первым делом


 
Александр Иванов ©   (2008-04-01 15:54) [3]

Проверял в первую очередь, с ним работает. Комментировал остальные условия - работает, раскомментирую хоть одно дополнительно - не работает.
Не работает - возвращает пустой набор данных.


 
clickmaker ©   (2008-04-01 16:00) [4]


> [3] Александр Иванов ©   (01.04.08 15:54)

outer join и and в where плохо сочетаются
если так

LEFT OUTER JOIN BannerTours ON PartnerCodes.ID = BannerTours.PartnerCodeID
and BannerTours.TourDate >= @DateFrom AND BannerTours.TourDate < @DateTo

ну и т.д.


 
Александр Иванов ©   (2008-04-01 16:03) [5]

Да, оно, спасибо.
Теперь не могу избавиться от мысли - значит раньше запрос работал неверно? :) Так как был JOIN и условие тоже, но что-то возвращал :)


 
clickmaker ©   (2008-04-01 16:07) [6]


> Так как был JOIN и условие тоже, но что-то возвращал :)

ну когда по joiny что-то находил, то условие срабатывало, естественно


 
Johnmen ©   (2008-04-01 16:13) [7]

Данный запрос [0] вообще не должен возвращать верные результаты, если таблицы, соединяемые с основной, не являются справочниками.
А во-вторых, IsNull лишнее. По определению.


 
Александр Иванов ©   (2008-04-01 16:16) [8]


> А во-вторых, IsNull лишнее. По определению.

Спасибо. Добавил в свое время, так как сумма вернула NULL. Значит запрос действительно был неверный изначально.


 
Johnmen ©   (2008-04-01 16:21) [9]


>  Добавил в свое время, так как сумма вернула NULL

Так м.б. если все складываемые значения оказались NULL.
Поскольку лично я не представляю такой ситуации, то написал [7] про IsNull. Хотя теоретически возможно...


 
evvcom ©   (2008-04-11 10:22) [10]

если SUM складывает только нульные значения, то возвращается null, потому для такого случая IsNull все же не лишний.



Страницы: 1 вся ветка

Текущий архив: 2008.10.12;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.022 c
2-1220437821
Term
2008-09-03 14:30
2008.10.12
AdvStringGrid


4-1197306592
kernel
2007-12-10 20:09
2008.10.12
список dll


3-1204791768
Tzw
2008-03-06 11:22
2008.10.12
Выборка через процедуру, Firebird 2.0


2-1220012874
ZiZi
2008-08-29 16:27
2008.10.12
Железки... Как разговаривать с дровами под NT.


1-1200175909
istok
2008-01-13 01:11
2008.10.12
Совпадение PID ов в разных сессиях...