| 
| 
 | Вопрос # 4 267/ вопрос открыт / | 
 |  Приветствую, уважаемые эксперты!Подскажите пожалуйста! Ввожу данные в TEdit после нажатия на кнопку "Добавить", данные добавляются в БД, если данные совпадают, которые хранятся в БД, введенные в TEdit, то выводится сообщение, что такие данные существуют, если нет то добавляются данные в БД, которые были введены в TEdit.
 В качестве СУБД используется Мicrosoft Аccеss.
 Доступ к базе осуществляется посредством технологи АDО.
 Для отображения данных используется компонент BDGrid. Большое спасибо!
 
|  |   Вопрос задала: Geny (статус: Посетитель)Вопрос отправлен: 2 июня 2010, 12:34
 Состояние вопроса: открыт, ответов: 1.
 |  Ответ #1. Отвечает эксперт: Vic Здравствуйте, Geny!Надо использовать TADOQuery и TADOCommand
 в ADOQuery пишем запрос
 SELECT * FROM нужная таблица WHERE искомое поле = :parameter
 в качесте параметра :parameter - текст из Tedit:
 ADOCommand.text:='Insert INTO нужная таблица (нужное поле) VALUES (:parameter)
 
 ADOQuery.Close;
 ADOQuery.Parameters[0].Value:=Tedit.Text
 ADOQuery.Open
 if not ADOQuery.eof then
 Begin
 ShowMessage('Введенное значение уже есть');
 exit;
 end
 else
 begin
 ADOCommand.Parameters[0].Value:=Tedit.Text;
 ADOCommand.Execute;
 end;
 
|  | Ответ отправил: Vic (статус: 1-ый класс)Время отправки: 2 июня 2010, 15:44
 Оценка за ответ: 5
 Комментарий к оценке: Большое спасибо, все получилось!!! |  
 Мини-форум вопросаВсего сообщений: 1; последнее сообщение — 2 июня 2010, 13:01; участников в обсуждении: 1. 
|   | Вадим К (статус: Академик), 2 июня 2010, 13:01 [#1]:Вначале делается запрос с помощью SELECT и смотрится, нет ли таких данных, а потом уже решается добавлять или нет данные. В некоторых случаях можно сделать поле ключевым и уникальным - в таком случае сама СУБД не даст сделать дубликат поля. Галочка "подтверждения прочтения" - вселенское зло. |  Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте. |