Главная страница
    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.45 MB
Время: 0.014 c
2-1140528664
Лёха
2006-02-21 16:31
2006.03.12
как преобразовать hwnd в string


15-1140018843
XeON
2006-02-15 18:54
2006.03.12
Лицензия Delphi 6 personal


2-1140535462
zxcv
2006-02-21 18:24
2006.03.12
как освобождать память, выделенную под массив


3-1137613145
Dataqbazer
2006-01-18 22:39
2006.03.12
Как правльно? в чем может быть ошибка?


2-1140611437
denis24
2006-02-22 15:30
2006.03.12
Удаление контролов с формы в цикле





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский