Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 18.12.2009, 10:53
Аватар для Sk@zk@
Sk@zk@ Sk@zk@ вне форума
Прохожий
 
Регистрация: 18.12.2009
Сообщения: 12
Репутация: 10
По умолчанию Вопрос по Delphi и Access

Здравствуйте. У меня такая проблема: мне надо из нескольких LookupComboBox на форме сделать запись в табилицу(каждый из них записывается в отдельный столбец) в базу данных MS Access. Эту базу я подключила с помощью ADOConnection (спасибо статье на сайте). Понимаю, что надо тоже делать через компоненты ADO, но попробовала несколько вариантов и не получается. Еслиб было больше времени, разобралась бы сама(думаю это уже разбиралось много раз), но программу нужно сдать очень скоро
Заранее спасибо за помощь.
Ответить с цитированием
  #2  
Старый 18.12.2009, 11:20
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Добавьте на форму компонент TAdoTable и TDataSource.
Свяжите TDataSource с TAdoTable через свойство DataSet
Свяжите TAdoTable с TAdoConnection через свойство Connection
Замените компоненты LookupComboBox на DBLookupComboBox
Заполните для DBLookupComboBox свойства:
DataSource
DataField
ListSource
ListField
KeyField
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #3  
Старый 18.12.2009, 12:23
Аватар для Sk@zk@
Sk@zk@ Sk@zk@ вне форума
Прохожий
 
Регистрация: 18.12.2009
Сообщения: 12
Репутация: 10
По умолчанию

Эм... я несовсем это имела ввиду... DBLookupComboBox я уже связала с базой данных, тоесть список открывается и там можно что-то выбрать. Ещё на этой же форме я добавила кнопку, при нажатии на которую то что выбрано в DBLookupComboBox должно записываться в таблицу (в той же базе данных). Вот это сделать у меня и не получается. При нажатии на кнопку только ошибки выкидывает
Ответить с цитированием
  #4  
Старый 18.12.2009, 13:03
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

А и не надо никакой кнопки. Принцип работы DBLookupComboBox это взять справочное значение и внести в основную таблицу автоматом.
Именно поэтому нужно заполнить 5 полей, а не 2.
Если вам надо брать справочное значение, и принимать решение о его вводе в таблицу позже, то для этого надо использовать уже DBComboBox.
Но вообще лучше выложите код, думаю быстрее найдем ошибку.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #5  
Старый 18.12.2009, 13:47
Аватар для Sk@zk@
Sk@zk@ Sk@zk@ вне форума
Прохожий
 
Регистрация: 18.12.2009
Сообщения: 12
Репутация: 10
По умолчанию

При нажатии на кнопку поидее должна быть запись в таблицу. ADOQuery я добавила и связала его с ADOConnection. А в SQL написала SELECT * FROM ...(таблица к которую нужно записать данные).
Код:
procedure TForm1.BitBtn1Click(Sender: TObject);
var
str:string;
begin
ADOQuery1.close;
ADOQuery1.SQL.clear;
str:='insert into [Таблица заказов] values('''+
  DBLookupComboBox1.Text+''')';
ADOQuery1.SQL.Add(str);
ADOQuery1.ExecSQL;
ADOQuery1.Open;
end;
Admin: Пользуемся тегами!

Не знаю, как сделать так чтобы записывалось в определенный столбец (а то он наверно в первый записывает, а у меня там ключевое поле)
P.S. Код скопировала из одной программы (там примерно тоже самое делают, заполняются поля, выбирается из списка, а потом после нажатия на кнопку идет запись в таблицу).

Последний раз редактировалось Admin, 18.12.2009 в 14:50.
Ответить с цитированием
  #6  
Старый 18.12.2009, 16:46
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Ну тут два варианта, либо настраивать по человечески лукап, либо написать правильно запрос
Код:
str:='insert into [Таблица заказов] (fieldname) values('''+
  DBLookupComboBox1.Text+''')';
Вместо fieldname вставьте название своего поля.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.

Последний раз редактировалось Страдалецъ, 18.12.2009 в 16:49.
Ответить с цитированием
  #7  
Старый 19.12.2009, 11:15
Аватар для Sk@zk@
Sk@zk@ Sk@zk@ вне форума
Прохожий
 
Регистрация: 18.12.2009
Сообщения: 12
Репутация: 10
По умолчанию

Вроде исправила запрос:
Код:
ADOQuery1.close;
ADOQuery1.SQL.clear;
str:='insert into [Таблица заказов] (Платформа) values('''+
  DBLookupComboBox1.Text+''')';
ADOQuery1.SQL.Add(str);
ADOQuery1.ExecSQL;
ADOQuery1.Open;
При нажатии на кнопку выкидывает такую ошибку: "Текущий поставщик не поддерживает возврат нескольких наборов записей в результате выполнения одной операции".
Ответить с цитированием
  #8  
Старый 19.12.2009, 15:30
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Правильно, потому-что вы пишете текст исполняемого запроса, он у вас отрабатывает:
Код:
ADOQuery1.ExecSQL;
а потом вы уже при том-же запросе на добавление пытаетесь получить набор записей:
Код:
ADOQuery1.Open;
Если уж хотите посмотреть на данные, сразу после добавления, то делайте так:
Код:
ADOQuery1.close;
ADOQuery1.SQL.Text := 'insert into [Таблица заказов] (Платформа) values('''+DBLookupComboBox1.Text+''')';
ADOQuery1.ExecSQL;
ADOQuery1.SQL.Text := 'select * from [Таблица заказов] where [Платформа]='+QuotedStr(DBLookupComboBox1.Text);
ADOQuery1.Open;
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 23:06.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter