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

Вниз

Уважаемые мастера!   Найти похожие ветки 

 
Tornado ©   (2002-09-25 14:23) [0]

Есть запрос из большой таблицы (более 300 000 записей, БД Access). Запрос выполняется с помощью ADOQuery. Все отображается в гриде. Как мне добавлять/удалять/редактировать какую либо запись из этого запроса чтобы пользователь сразу мог увидеть эти изменения в гриде? Нужно использовать еще один ADOQuery? И как поставить условие в запросе редактирования/удаления/добаления чтоб модифицировалась именно та запись, на которой стоит курсор? Если можно - кусочек кода. Спасибо огромное.


 
sniknik ©   (2002-09-25 14:43) [1]

модифицировать по ключевому полю, возмеш ключь из текущей измениш ее.
лутше не еще один ADOQuery а еще ADOCommand (для UPDATE сомое то) и после изменений рефреш основному ADOQuery.


 
Tornado ©   (2002-09-25 15:26) [2]

Уважаемый sniknik © (25.09.02 14:43) !

Можно поподробней насчет ключевого поля? Как получить ключ? Если не сложно, никогда не работал с ADO. Спасибо


 
sniknik ©   (2002-09-25 16:03) [3]

зачем персонализировать вопрос? тут тебе многие могут ответить, а будеш ждать меня а я вообще домой может ушел.

ключевое поле это в принципе любое поле по которому можно 100% индентефицировать запись (уникальное). можно по разному добиватся уникальности проще по моему Автоинкрементное поле, для гарантии еще индекс на него не позволяюций дубляжей (в MSSQL кластерный индекс, чтобы в этом порядке поля держал) и т.д.
но в общем Автоинкремента вполне хватит.

ну вот когда имеется такое поле то можно делать
ADOCommand.CommandText:= "UPDATE BAR SET BARCODE= ""5449000000286"" WHERE INCREM = 13";
ADOCommand.Execute;

обновится запись где INCREM равно 13
INCREM здесь именно оно ключевое поле.


 
Tornado ©   (2002-09-25 16:36) [4]

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


 
sniknik ©   (2002-09-25 16:56) [5]

читай.
VarINCREM:= ADOQuery.FieldByName("INCREM").Value;

и передавай
ADOCommand.CommandText:= "UPDATE BAR SET BARCODE= ""5449000000286"" WHERE INCREM = "+IntToStr(VarINCREM);

можно и параметром
ADOCommand.CommandText:= "UPDATE BAR SET BARCODE= ""5449000000286"" WHERE INCREM = :Inc";
ADOCommand.Params.ParamByName("Inc").Value:= VarINCREM;



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

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

Наверх




Память: 0.47 MB
Время: 0.012 c
7-56377
Aga
2002-08-06 08:31
2002.10.17
Win


1-56191
margol
2002-10-07 14:59
2002.10.17
Работа с файлами


14-56294
wolfic
2002-09-23 18:24
2002.10.17
где найти IBObjects без окна сообщения


4-56416
Витёк
2002-09-04 23:00
2002.10.17
Проблемы с System Area (Shell_NotifyIcon)


4-56403
Dest
2002-08-31 10:09
2002.10.17
Иконка в чужом exe