Четверг, 09 Май 2024, 05:14
Uchi.ucoz.ru
Меню сайта
Форма входа

Категории раздела
Высшая математика [11]
Экономическая социология [95]
Основы Менеджмента [64]
Бухгалтерский учёт [157]
Философия [163]
Мировая Экономика [603]
Бизнес планирование [29]
Финансирование и кредитование инвест [105]
Ценообразование [46]
Гражданское право [196]
Права Человека [173]
Основы Маркетинга [207]
Основы энергосбережения [55]
Информатика [0]
Экология и устойчивое развитие [0]
Физика для студентов [0]
Основы права [0]
Политология [0]
Не стандартные примеры на Delphi [169]
Примеры на Delphi7 [108]
Алгоритмы [94]
API [110]
Pascal [152]
Базы Данных [6]
Новости
Чего не хватает сайту?
500
Статистика
Зарегистрировано на сайте:
Всего: 51635


Онлайн всего: 58
Гостей: 58
Пользователей: 0
Яндекс.Метрика
Рейтинг@Mail.ru

Каталог статей


Главная » Статьи » Студентам » Не стандартные примеры на Delphi

Поиск существующей записи перед тем, как она будет вставлена
Если вы находитесь в режиме редактирования (Edit) или вставки (Insert), то
при изменении режима вы автоматически делаете постинг записи. И, естественно,
при наличие дубликата (неуникальности) записи, вы получите ошибку. Способ обойти
это - использовать другой компонент TTable, связанный с той же таблицей, и
осуществляющий по ней поиск. Этот путь самый простой и эффективный.

Воспользуйтесь двумя компонентами TTable (оба должны указывать на одну и ту
же таблицу). Используйте один для поиска, а второй для редактирования.

Ваша "ключевая" таблица BDE будет автоматически генерировать исключения, если
пользователь будет пытаться послать созданный им дублирующий ключ. Для установки
таблицы используйте Database Desktop.

Создайте на основе поля первичный индекс (Primary Index). Затем создайте
какой-то обработчик DB-исключения для нашего "нарушения уникальности".

Моя технология заключается в следующем: в отдельной форме я предлагаю
пользователям ввести часть записи, которая должна быть уникальна (обычно одно
поле). Затем для проверки существования я делал FindKey. Если он находился,
через MessageDlg я информировал пользователя, и возвращал его на форму
редактирования, не создавая новой записи. Помните, что если FindKey ничего не
находит, dbCursor никуда не перемещается, и закладка не нужна. Если запись
найдена, она немедленно будет отображена на форме редактирования для того, чтобы
пользователь смог увидеть ее содержимое. В противном случае происходит
следующее:

Table.Append;
Table.FieldByName('KeyField').AsString :=
UserEntry;
{ ... позволяем пользователю редактировать все
остальные поля записи ... }
{ в это время кнопка Cancel должна быть активной для того,
чтобы
дать возможность пользователю отменить ввод новой записи.
}
Категория: Не стандартные примеры на Delphi | Добавил: Lerka (22 Ноя 2012)
Просмотров: 418 | Рейтинг: 1.0/ 3 Оштрафовать | Жаловаться на материал
Похожие материалы
Всего комментариев: 0

Для блога (HTML)


Для форума (BB-Code)


Прямая ссылка

Профиль
Четверг
09 Май 2024
05:14


Вы из группы: Гости
Вы уже дней на сайте
У вас: непрочитанных сообщений
Добавить статью
Прочитать сообщения
Регистрация
Вход
Улучшенный поиск
Поиск по сайту Поиск по всему интернету
Наши партнеры
Интересное
Популярное статьи
Портфолио ученика начальной школы
УХОД ЗА ВОЛОСАМИ ОЧЕНЬ ПРОСТ — ХОЧУ Я ЭТИМ ПОДЕЛИТ...
Диктанты 2 класс
Детство Л.Н. Толстого
Библиографический обзор литературы о музыке
Авторская программа элективного курса "Практи...
Контрольная работа по теме «Углеводороды»
Поиск
Главная страница
Используются технологии uCoz