Главная страница
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.015 c
14-56290
FLIZ
2002-09-20 14:48
2002.10.17
народ, а что вы делаете когда думаете? ручку грызете,


7-56372
Juve
2002-08-09 23:19
2002.10.17
Глючит 2000!


1-56126
Лана Розанова
2002-10-09 11:36
2002.10.17
Вызов из странички


7-56384
_landy
2002-08-12 15:06
2002.10.17
Multicast


1-56114
Nomad.kz
2002-10-09 09:33
2002.10.17
в двух соснах заблудился :-) - это про TIcon