Главная страница
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.021 c
2-1220512873
harisma
2008-09-04 11:21
2008.10.12
Поиск фразы в бинарном файле


1-1198176914
Dronishe
2007-12-20 21:55
2008.10.12
Анимация формы окна


2-1220268091
workbench
2008-09-01 15:21
2008.10.12
Запрет закрытия консольного окна


15-1219305496
Int23
2008-08-21 11:58
2008.10.12
Программа для конвертации html в word


15-1219471047
Simpson
2008-08-23 09:57
2008.10.12
Указатель класса на самого себя