Экспертная система Delphi.int.ru

Сообщество программистов
Общение, помощь, обмен опытом

Логин:
Пароль:
Регистрация | Забыли пароль?

Delphi.int.ru Expert

Другие разделы портала

Переход к вопросу:

#   

Статистика за сегодня:  


Лучшие эксперты

Подробнее »



Вопрос # 4 267

/ вопрос открыт /

Приветствую, уважаемые эксперты!
Подскажите пожалуйста! Ввожу данные в TEdit после нажатия на кнопку "Добавить", данные добавляются в БД, если данные совпадают, которые хранятся в БД, введенные в TEdit, то выводится сообщение, что такие данные существуют, если нет то добавляются данные в БД, которые были введены в TEdit.
В качестве СУБД используется Мicrosoft Аccеss.
Доступ к базе осуществляется посредством технологи АDО.
Для отображения данных используется компонент BDGrid. Большое спасибо!

Geny Вопрос ожидает решения (принимаются ответы, доступен мини-форум)

Вопрос задала: 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 и смотрится, нет ли таких данных, а потом уже решается добавлять или нет данные. В некоторых случаях можно сделать поле ключевым и уникальным - в таком случае сама СУБД не даст сделать дубликат поля.
Галочка "подтверждения прочтения" - вселенское зло.

Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.

Версия движка: 2.6+ (26.01.2011)
Текущее время: 22 февраля 2025, 11:32
Выполнено за 0.02 сек.