Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 05.11.2008, 21:51
srr srr вне форума
Прохожий
 
Регистрация: 21.04.2008
Сообщения: 10
Версия Delphi: Delphi7
Репутация: 10
По умолчанию Контроль ввода данных

Помогите плз с вводом в DBEdit, чтобы ругалось, что "такой номер прибора уже существует". База пока Access, ADOConnect, ADOQuery.
Ответить с цитированием
  #2  
Старый 06.11.2008, 16:26
Interface Interface вне форума
Активный
 
Регистрация: 23.05.2008
Адрес: Россия, Уфа
Сообщения: 203
Репутация: 1
Стрелка

Я в ваших "базах" ниче не понимаю... Зато могу помочь с ограничением ввода в Edit:
Код:
procedure TForm1.Edit1KeyPress(Sender: TObject; var Key: Char);
begin
  if not (Key in [#8,'0'..'9']) then Key := #0; // Пишем циферки
end;
...
Procedure Button1.Click...
var
nomera : array of Integer; //масив "номеров" (его надо перед implementation прописывать)
KolvoNomerov, a : Integer; // всего номеров.
begin
For a := 0 to KolVoNomerov do // цикл проверки
If StrToInt(Edit1.Text) = Nomera[a] then
MessageBox(Form1.Handle,Такой номер прибора уже существует!','Ошибка!', 0);
// выводим ошибку
Повторюсь ... я в базах я 0!
Надеюсь я помог...
P.S. И зачем вам нужны эти DBEdit ы ...
__________________
Я ни в чем никогда не уверен... И в этом тоже...
Ответить с цитированием
  #3  
Старый 06.11.2008, 16:26
Interface Interface вне форума
Активный
 
Регистрация: 23.05.2008
Адрес: Россия, Уфа
Сообщения: 203
Репутация: 1
Стрелка

Я в ваших "базах" ниче не понимаю... Зато могу помочь с ограничением ввода в Edit:
Код:
procedure TForm1.Edit1KeyPress(Sender: TObject; var Key: Char);
begin
  if not (Key in [#8,'0'..'9']) then Key := #0; // Пишем циферки
end;
...
Procedure Button1.Click...
var
nomera : array of Integer; //масив "номеров" (его надо перед implementation прописывать)
KolvoNomerov, a : Integer; // всего номеров.
begin
For a := 0 to KolVoNomerov do // цикл проверки
If StrToInt(Edit1.Text) = Nomera[a] then
MessageBox(Form1.Handle,Такой номер прибора уже существует!','Ошибка!', 0);
// выводим ошибку
Повторюсь ... я в базах я 0!
Надеюсь я помог...
P.S. И зачем вам нужны эти DBEdit ы ...
----------------------------------------------------------------------------------
Админ!
Сдеайте плиз так что б ТАК не получалось!!! ="(((
__________________
Я ни в чем никогда не уверен... И в этом тоже...
Ответить с цитированием
  #4  
Старый 06.11.2008, 18:47
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,100
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Ставишь UNIQUE на поле с номером.
При сохранении тебе база ругнется, если попытаешься вставить уже существующий. Только останется понять что за ругань идет и вывести человеческое сообщение. Для начала просто выводи то, что выдает тебе база, там посмотришь как можно определить. Обычно в этом случае появляется сообщение типа Violation unique contraint bla-bla-bla... (bla-bla-bla - имя ограничения).

Т.е. для начала одлжно выглядеть так:
Код:
Try
   ADOQuery1.Post;
Except
  On E : Exception Do
    Begin
       ShowMessage('Ошибка: ' +E.Message);
       // Add additional code here...
    End;
End;
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 01:05.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025