Главная страница
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.47 MB
Время: 0.017 c
4-1188489972
паЗер
2007-08-30 20:06
2008.05.11
изменение рисунка рабочего стола..


10-1145888035
Ling
2006-04-24 18:13
2008.05.11
Диаграммы в Excell


2-1207938850
Rhammer
2008-04-11 22:34
2008.05.11
Разбитые винраром архивы на part


2-1207910646
webpauk
2008-04-11 14:44
2008.05.11
Pointer & array


15-1206091656
gidravlikus
2008-03-21 12:27
2008.05.11
База данных Access