Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2008.05.11;
Скачать: CL | DM;

Вниз

Delphi и MS SQL   Найти похожие ветки 

 
Леонид   (2007-12-05 16:32) [0]

Помогите пожалуйста - я сделал в первой форме два списка - Отдел и Сотрудники, во второй форме DBGrid в котором можно редактировать данные, с отделами все окей, а вот с сотрудниками проблема, мне нужно что бы как-то им задавался id отдела куда я хочу добавить его... Т.е. что бы DBNavigator понял что сотрудника нужно добавлять не с пустым id а с установленным мной, выводить в DBGrid полем id отдела нельзя, т.к. по идее отдел уже выбран изначально тот куда я буду забивать сотрудника.


 
Леонид   (2007-12-05 16:45) [1]

Собственно делается как я понимаю это так:

procedure TForm4.ADOQuery1BeforePost(DataSet: TDataSet);
begin
 if (SelName = "СОТРУДНИК") then
 begin
 DataSet.FieldByName("ID").AsInteger := integer(Form3.ComboBox2.Items.Objects[Form3.ComboBox2.ItemIndex]);
 end;  
end;


 
Германн ©   (2007-12-06 01:35) [2]


> Леонид   (05.12.07 16:45) [1]

Если я всё правильно понял (а это не очень просто было сделать, учитывая "обрывочность" информации), то такие поля записи удобнее заполнять в событии OnNewRecord.


 
Германн ©   (2007-12-06 02:46) [3]


> Леонид   (05.12.07 16:45) [1]

А за "ADOQuery" тебя пожурят другие люди, более продвинутые, чем я. :)


 
Johnmen ©   (2007-12-06 09:03) [4]

Читать про lookup-поля и не заниматься ерундой. Ещё лучше - элементарную книжку про программирование баз данных.


 
ЮЮ ©   (2007-12-06 10:05) [5]

> Т.е. что бы DBNavigator понял что сотрудника нужно добавлят

Уж кому-кому, а DBNavigator-у точно все пофиг :) Его дело Insert и Post выполнить.

Проще всего связать DataSet-ы как мастер-детайл (TDataSet.DataSource), и тогда в DataSet-е Сотрудники будут толко записи, соответствующие текущей в DataSet-е Отдел. Соответстаенно при вставке новой записи в Сотрудники вствится нужное Id. По крайней мере это работало а BDE. В ADO "батонокидательством" не занимаюсь :)



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

Текущий архив: 2008.05.11;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.016 c
2-1208159878
antonn (work)
2008-04-14 11:57
2008.05.11
int64 и перевод в строку


15-1206806482
Denis__
2008-03-29 19:01
2008.05.11
KERNEL32.DLL


2-1207725582
Footballer
2008-04-09 11:19
2008.05.11
UDP


15-1206469141
@!!ex
2008-03-25 21:19
2008.05.11
оцените пожалуйста код


15-1206598832
@!!ex
2008-03-27 09:20
2008.05.11
автоматический вход в систему и подключение инета