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

Вниз

Помогите найти ошибка - кроме головы? =)   Найти похожие ветки 

 
Владий ©   (2004-03-02 11:12) [0]

Есть следующий код:

SELECT Payments.*, LastCoursEUR.Cours*Payments.Sum AS SumPlanRub, Polices.*
FROM Polices INNER JOIN (LastCoursEUR INNER JOIN Payments ON LastCoursEUR.Val=Payments.Val) ON Polices.P_Num=Payments.Police
WHERE ((Payments.Val)="EUR") And (Payments.Payed =0) And (Payments.Date<Now())
Union
SELECT Payments.*, LastCoursUSD.Cours*Payments.Sum AS SumPlanRub, Polices.*
FROM Polices INNER JOIN (LastCoursUSD INNER JOIN Payments ON LastCoursUSD.Val=Payments.Val) ON Polices.P_Num=Payments.Police
WHERE ((Payments.Val)="EUR") And (Payments.Payed =0) And (Payments.Date<Now())
UNION
SELECT Payments.*, Payments.Sum AS SumPlanRub, Polices.*
FROM Polices INNER JOIN Payments ON Polices.P_Num=Payments.Police
WHERE ((Payments.Val)="EUR") And (Payments.Payed =0) And (Payments.Date<Now());

Не работает, зараза... Причем, подозреваю, что из-за
"(Payments.Date<Now())" - такие записи точно есть, хотя может в написании ошибся? Но на ошибки ругани нет...

Хорошей Удачи!
Владий // ICQ: 47659886


 
Reindeer Moss Eater ©   (2004-03-02 11:17) [1]

Надо верить движку.
Нет записей в выборке - значит нет их.


 
Владий ©   (2004-03-02 11:23) [2]

Есть, в том-то и дело... 100% есть запись от 29.01.2004, сегодня - 02.03.04 => должно быть, а нету...

Хорошей Удачи!
Владий // ICQ: 47659886


 
sniknik ©   (2004-03-02 11:23) [3]

> такие записи точно есть
в одной таблице может быть, но в сумме условие не сходится, их (условий) у тебя довольно много, двойное обьеденение, тем более с INNER, что значит если хоть по одной таблице подходяших записей нет то нет их и в общем.
а Now правильно.


 
Johnmen ©   (2004-03-02 11:28) [4]

А так ?
SELECT Payments.*, LastCoursEUR.Cours*Payments.Sum AS SumPlanRub, Polices.*
FROM Payments
JOIN Polices ON Polices.P_Num=Payments.Police
JOIN LastCoursEUR ON LastCoursEUR.Val=Payments.Val
WHERE (Payments.Val="EUR") And (Payments.Payed =0) And (Payments.Date<Now())
UNION
SELECT Payments.*, LastCoursUSD.Cours*Payments.Sum AS SumPlanRub, Polices.*
FROM Payments
JOIN Polices ON Polices.P_Num=Payments.Police
JOIN LastCoursUSD ON LastCoursUSD.Val=Payments.Val
WHERE (Payments.Val="EUR") And (Payments.Payed =0) And (Payments.Date<Now())
UNION
SELECT Payments.*, Payments.Sum AS SumPlanRub, Polices.*
FROM Payments
JOIN Polices ON Polices.P_Num=Payments.Police
WHERE (Payments.Val="EUR") And (Payments.Payed =0) And (Payments.Date<Now())


 
sniknik ©   (2004-03-02 11:43) [5]

Johnmen ©   (02.03.04 11:28) [4]
а так в access работать не будет (join не вложенный, он не понимает), тогда уж лутше просто в условии равенство указать (неявный джойн сделать)


 
Reindeer Moss Eater ©   (2004-03-02 11:47) [6]

В каждом из запросов 3 условия по AND

Последовательно убираем по одному и начинаем видеть какое именно приводит к пустой выборке.


 
sniknik ©   (2004-03-02 11:54) [7]

Reindeer Moss Eater ©   (02.03.04 11:47) [6]
вместе с джойнами 5 AND.


 
Владий ©   (2004-03-02 11:56) [8]

Спасибо за ответы - не нашел что приводило к пустой выборке - но заработало... видимо опять где-то пробел пропустил...



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

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

Наверх




Память: 0.48 MB
Время: 0.033 c
3-1078819320
denik
2004-03-09 11:02
2004.04.04
Каким образом выйти из режима редактирования?


1-1079104462
Ysp1
2004-03-12 18:14
2004.04.04
Есть Handle как узнать путь к ехе-шнику


14-1078851705
VDen
2004-03-09 20:01
2004.04.04
выделение подстроки на Perl


11-1057266293
Stargazer
2003-07-04 01:04
2004.04.04
И вновь TBitBtn - преобразование цветов


7-1074709981
Nick_Omsk
2004-01-21 21:33
2004.04.04
Есть ли Windows DDK на русском языке. Если есть, то где?