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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 10.01.2011, 21:36
Crocodil Crocodil вне форума
Прохожий
 
Регистрация: 01.01.2011
Сообщения: 4
Репутация: 10
По умолчанию Проверка значения поля

Здравствуйте!
Возникла необходимость взяться за Delphi. Приходится осваивать. Не могу справиться с проблемой: Есть база данных в Access. Поля: счётчик, Артикул и Наименование. Каждому Артикул соответствует своё Наименование. Вообщем DBGrid отоброжает всё благополучно. Поиск прописан следующим образом:

PHP код:
procedure TForm2.dbgrid1KeyPress(SenderTObject; var KeyChar);
begin
artikul
:=artikul+key;
dbgrid1.DataSource.DataSet.Locate('Артикул',artikul,[loPartialKey]);
StatusBar1.Panels.Items[0].Text:='Поиск:'+artikul;
end
Поиск ведётся по Артикулу. Далее надо чтобы при нажатии на кнопку "Далее" проводилась проверка //если соответствующее найденному артикулу наименование = 'гвозди' - тогда открыть форму 2, если соответствующее данному артикулу наименование = 'гайки' - тогда открыть форму 3, и т.д.
Так вот моих познаний не хватает для того чтобы прописать значение поля из выделенной строки как строковую переменную.
Подскажите, пожалуйста, как это сделать. Или может я не в том направлении ищу?

Последний раз редактировалось Crocodil, 10.01.2011 в 21:41.
Ответить с цитированием
  #2  
Старый 10.01.2011, 22:19
stil stil вне форума
Новичок
 
Регистрация: 24.11.2010
Сообщения: 91
Репутация: 41
По умолчанию

Код:
dbgrid1.DataSource.DataSet.FieldByName('имяполя').AsString;
или
dbgrid1.DataSource.DataSet.Fields[номерполя].AsString;
Ответить с цитированием
  #3  
Старый 11.01.2011, 19:24
Crocodil Crocodil вне форума
Прохожий
 
Регистрация: 01.01.2011
Сообщения: 4
Репутация: 10
По умолчанию

Спасибо! Буду пробовать!
Ответить с цитированием
  #4  
Старый 11.01.2011, 20:23
Crocodil Crocodil вне форума
Прохожий
 
Регистрация: 01.01.2011
Сообщения: 4
Репутация: 10
По умолчанию

Уважаемый Stil, что-то не выходит каменный цветок
Код:
procedure TForm2.dbgrid1KeyPress(Sender: TObject; var Key: Char);
begin
obozn:=obozn+key;
dbgrid1.DataSource.DataSet.Locate('Обозначение',obozn,[loPartialKey]);
StatusBar1.Panels.Items[0].Text:='Поиск:'+obozn;
end;

procedure TForm2.Button3Click(Sender: TObject);

var naim: string;
begin
naim:=dbgrid1.DataSource.DataSet.FieldByName('Наименование').AsString;
if naim = 'Корпус сверла Shark Drill HP4'
then
  begin
    Hide;
    Form4.Show;
    Exit;
  end;
if naim = 'Пластина сверла Shark Drill HP4'
then
  begin
    Hide;
    Form5.Show;
    Exit;
  end;
end;
Ошибок никаких не выводит, но не работает, формы не открываются.
Не могу понять, в чём дело
Ответить с цитированием
  #5  
Старый 18.01.2011, 19:38
Аватар для hardcor4uk
hardcor4uk hardcor4uk вне форума
Прохожий
 
Регистрация: 18.01.2011
Сообщения: 3
Репутация: 10
По умолчанию

Попробуй дописать функцию Trim.
может быть из за какого нить пробела она и не хочет сравнивать;
naim:=Trim(dbgrid1.DataSource.DataSet.FieldByName( 'Наименование').AsString);
или попробуй
naim:=dbgrid1.DataSource.DataSet.FieldByName('Наим енование').value;
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter