Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Начинающим";
Текущий архив: 2006.03.12;
Скачать: [xml.tar.bz2];

Вниз

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

 
BillyJeans   (2006-02-21 13:54) [0]

Почему выполнение следующего кода:

ADOQuery.SQL.Clear;
ADOQuery.SQL.Add("SELECT Table1.*, Table2.Name AS Name, Table3.X AS X");
ADOQuery.SQL.Add(" FROM Table1 LEFT JOIN Table2 ON Table1.RouteID = Table2.ID ");
ADOQuery.SQL.Add(" LEFT JOIN Table3 ON Table1.StopID = Table3.ID ");
ADOQuery.SQL.Add(" WHERE RouteID="+IntToStr(Value));
ADOQuery.SQL.Add(" ORDER BY Table1.SOrder");
ADOQuery.Open;

Выдает сообщение об ошибке:
Ошибка синтаксиса (пропущен оператор) в выражении запроса "Table1.RouteID = Table2.ID LEFT JOIN Table3 ON Table1.StopID = Table3.ID"
?


 
msguns ©   (2006-02-21 14:01) [1]

..FROM Table1 LEFT JOIN Table2 ON (Table1.RouteID = Table2.ID)..


 
msguns ©   (2006-02-21 14:03) [2]

Ооо.. Да это еще не все..
Для объединения с более чем одной таблицей надо использовать вложенный (через "()") джоин


 
BillyJeans   (2006-02-21 14:23) [3]

приведи пример вложенного джоин


 
BillyJeans   (2006-02-21 14:25) [4]

MySQL проглатывает эту запись на ура, а вот ADO в связке с Access плюётся :-(


 
msguns ©   (2006-02-21 14:31) [5]

Не пишу в этот форум готовых сиквелей. Принципиально.
Подскажу: вложенные джоины делаются аналогично вложенным селектам.

"Тренеруй" сиквели в самом акцесе - будет быстрее.


 
BillyJeans   (2006-02-21 14:42) [6]

Так джоин то не вложенный... В запросе требуется добавить к полям одной Table пару полей из других, вот!
Access суксь, сам и тренируй


 
msguns ©   (2006-02-21 15:06) [7]

>BillyJeans   (21.02.06 14:42) [6]
>Так джоин то не вложенный..

Правильно. Ты [2] читал ?
Если используешь акцес, то и подходи к нему с его заморочками, а не мускульными.

Написать запрос типа

Select A.*, B.Pole From (Select .. From T1 .. Left Join T2 On (T1.id=T2.id)) A
  Left Join T3 On (A.id=T3.id))

а потом "преобразовать" его в единственному селекту, но вложенному джоину слабо ?
Проверить работу запроса можно в самом акцесе. Если он там пройдет, почти гарантия, что его "возьмет" и ADO



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

Форум: "Начинающим";
Текущий архив: 2006.03.12;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.012 c
3-1137757377
_RusLAN
2006-01-20 14:42
2006.03.12
Нужна идея. Передача даных с одной БД в другую (FireBird)


2-1140985062
Vitalik__
2006-02-26 23:17
2006.03.12
Перевод значения String в число.


8-1126694605
Kair+
2005-09-14 14:43
2006.03.12
Захват видео с помощью DSPack


6-1129405704
Volf_555
2005-10-15 23:48
2006.03.12
Определение MAC-адреса УДАЛЁННОГО компьютера


1-1138970225
ORMADA
2006-02-03 15:37
2006.03.12
Pascal Script (Rem Object)





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский