Поиск:

Ответ в темуСоздание новой темы Создание опроса
> SQL запрос из связанных таблиц 
:(
    Опции темы
vslabchenko
Дата 5.5.2009, 15:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 11
Регистрация: 10.7.2007

Репутация: нет
Всего: нет



День добрый! Помогите,пожалуйста,разобраться.Есть две таблицы- Области(OblastID,Name_Oblast) и Контрагенты(ContragentsID,Oblast и т.п.).В таблице Contragents в поле Oblast данные выводятся в цифровом виде,а в поле Name_Oblast таблицы Oblast- в текстовом, именно сами названия областей.Связаны по полям OblastID-Oblast. На форме есть Grid,Edit,Button. В Gride все отображается отлично,проблемы наступают когда пытаюсь произвести выборку из базы Contragents о полю Oblast.Делаю так:

DataModule.QueryContragents.Active:=false;
DataModule.QueryContragents.SQL.Clear;
DataModule.QueryContragents.SQL.Add('SELECT*');
DataModule.QueryContragents.SQL.Add('FROM Contragents,Oblast');
DataModule.QueryContragents.SQL.Add('WHERE Contragents.Oblast=Oblast.OblastID '''+Edit2.Text+'''');
DataModule.QueryContragents.Active:=true;

В итоге при запуске приложения, вводе в Edit необходимого значения области и нажатии на Button работа приложения заканчивается и выдается сообщение :Project raised exception class EOIeException with message 'Line3:Incorrect syntax near 'Минская'.Process stopped.'
Помогите,пожалуйста,запутался... 
PM MAIL   Вверх
Akella
Дата 5.5.2009, 16:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 29
Всего: 329



Цитата(vslabchenko @  5.5.2009,  15:40 Найти цитируемый пост)
SELECT*

а пробелы...

Добавлено через 21 секунду
И оформи код тэгами, как положено.

Добавлено через 1 минуту и 29 секунд
Для большей читабельности лучше так:
Код
DataModule.QueryContragents.SQL.Add('WHERE Contragents.Oblast=Oblast.OblastID ' + QuotedStr(Edit2.Text));

PM MAIL   Вверх
Keeper89
Дата 5.5.2009, 16:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2580
Регистрация: 26.2.2009

Репутация: 1
Всего: 58



Цитата(Akella @  5.5.2009,  16:22 Найти цитируемый пост)
Для большей читабельности лучше так:

По-моему с параметрами будет еще лучше.


--------------------
PM MAIL WWW   Вверх
insoft
Дата 5.5.2009, 17:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 196
Регистрация: 14.2.2007
Где: Тюменская область , г.Тобольск

Репутация: 3
Всего: 3



vslabchenko, судя из ошибки, то неверный синтаксис
проще всего проверь запрос который у тебя получается
Код

ShowMessage(QueryContragents.SQL.text)
  smile 
PM MAIL WWW   Вверх
vslabchenko
Дата 7.5.2009, 16:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 11
Регистрация: 10.7.2007

Репутация: нет
Всего: нет



Спасибо всем ответившим, но это все не то... 
PM MAIL   Вверх
Kbl4AH
Дата 8.5.2009, 07:44 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 741
Регистрация: 1.4.2008
Где: Вятка

Репутация: 6
Всего: 15



Цитата(vslabchenko @  5.5.2009,  16:40 Найти цитируемый пост)
DataModule.QueryContragents.SQL.Add('WHERE Contragents.Oblast=Oblast.OblastID '''+Edit2.Text+'''');

это что такое? как ты это представляешь с точки зрения запроса?
Код

... WHERE Contragents.Oblast=Oblast.OblastID 'Минская' 

надо, наверное, так...
Код

select * from contragents, oblast where contragents.oblast = oblast.oblastid and oblast.name_oblast = 'Минская' 

То есть
Код

DataModule.QueryContragents.SQL.Add('WHERE Contragents.Oblast=Oblast.OblastID and oblast.name_oblast = ' + QuotedStr(Edit2.Text));

PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

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

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Vit, Петрович.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Базы данных и репортинг | Следующая тема »


 




[ Время генерации скрипта: 0.0688 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.