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

Вниз

DBNavigator.   Найти похожие ветки 

 
Liavik ©   (2003-11-04 12:41) [0]

Добрый день. Как при нажатии на кнопку навигатора, например, (nbInsert) инициировать следующий код
Var k:variant;
begin
DataModule1.Table2.Last;
k:=DataModule1.Table2IDDogovor.Value;
DataModule1.Table2.Insert;
DataModule1.Table2IDDogovor.Value:=k+1;
end;


 
Sandman25 ©   (2003-11-04 12:54) [1]

1. BeforeInsert

DataModule1.Table2.Last;
k:=DataModule1.Table2IDDogovor.Value;

2. AfterInsert

DataModule1.Table2IDDogovor.Value:=k+1;

Но в любом случае будет коряво.
Какая СУБД?


 
Skier ©   (2003-11-04 12:54) [2]

TDBNavigator.OnClick ?


 
Liavik ©   (2003-11-04 12:57) [3]

Да -TDBNavigator.OnClick


 
Liavik ©   (2003-11-04 13:07) [4]

Проблема в том, что по условию задания, в БД Access ключевые поля должны быть не счетчиками (ведение БД Delphi6). Нужно чтобы при нажатии на добавление записи в навигаторе программно добавлялось +1 ключевое поле таблицы. При запуске кода с buttona код работает верно.Как запустить его с помощью навигатора?


 
bon   (2003-11-04 16:35) [5]

procedure TDataForm.DBNavigator1Click(Sender: TObject;
Button: TNavigateBtn);
begin
if button=nbInsert then
begin
.....
.....
.....
end;

end;


 
Liavik ©   (2003-11-05 17:11) [6]

Спасибо bon, прёт! Насколько просто!


 
Sandman25 ©   (2003-11-05 17:25) [7]

[6] Liavik © (05.11.03 17:11)

Надеюсь, потом Вы не будете спрашивать, как сделать то же самое, если запись добавляется не дбнавигатором, а нажатием стрелки вниз на последней строке дбгрида :)


 
Liavik ©   (2003-11-05 17:34) [8]

Sandman25. Постараюсь не спрашивать, и обязательно попробую сделать сам, результат скажу поже:)


 
Sandman25 ©   (2003-11-05 17:52) [9]

[8] Liavik © (05.11.03 17:34)

Можно не мучиться, я уже написал решение в [1] :)


 
Vlad ©   (2003-11-05 17:56) [10]


> Sandman25 © (05.11.03 17:52) [9]
>
> Можно не мучиться, я уже написал решение в [1] :)


Хорошая концовка, у твоего решения :)
>Но в любом случае будет коряво


 
Sandman25 ©   (2003-11-05 18:00) [11]

[10] Vlad © (05.11.03 17:56)

Если хочешь, можешь ему объяснить, что лучше запускать select max(id) from table, а в случае Key Violation в OnUpdateError устанавливать новое значение NewValue в полученное еще раз через select max(id) from table и UpdateAction := uaRetry :)


 
Vlad ©   (2003-11-05 18:13) [12]

Объяснять не буду, потому как и такой вариант тоже не лучший, имхо.
Однозначно - на кнопку навигатора лучше это не делать.
Если уж автор так не хочет делать первичный ключ счетчиком, почему бы ему не сделать его обычным полем + добавить НЕ ключевое поле (фиктивное) - счетчик, откуда и брать новые значения.
Опять же, мое мнение, что в таких вопросах лучше использовать возможности сервера, а не выдумывать что-то самому.


 
Sandman25 ©   (2003-11-05 18:23) [13]

[12] Vlad © (05.11.03 18:13)

Конечно, при наличии serial либо спец. триггеров нужно их использовать, но я посчитал, что у автора БД типа DBF.

>почему бы ему не сделать его обычным полем + добавить НЕ ключевое поле (фиктивное) - счетчик, откуда и брать новые значения.

Так у него же именно так сейчас. Или нет?



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

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

Наверх




Память: 0.49 MB
Время: 0.053 c
14-79139
Mr.Ice
2003-10-31 14:21
2003.11.24
Подскажите как реализовать


1-78949
R
2003-11-12 04:08
2003.11.24
Оптимальность и целесообразность применения констант


3-78815
Davinchi
2003-11-04 13:14
2003.11.24
ошибка при установке фильтра в ADO таблице


7-79194
ZHK
2003-09-15 09:51
2003.11.24
Запуск сервиса из памяти


14-79143
ertong
2003-10-28 19:39
2003.11.24
Задача