Главная страница
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.021 c
1-1078826340
Джек
2004-03-09 12:59
2004.04.04
Параллельная работа двух задач


3-1078272937
Алексей
2004-03-03 03:15
2004.04.04
SQL запрос из трех баз


1-1079610606
Marser
2004-03-18 14:50
2004.04.04
Межплатформенный перенос


1-1079079215
ЕвгенийТ
2004-03-12 11:13
2004.04.04
запись текстового файла в DOS-кодировке


9-1063191841
Agent[007]
2003-09-10 15:04
2004.04.04
Создание своих типов...