Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
1 / 1 / 0
Регистрация: 11.10.2015
Сообщений: 150

Фильтрация данных

16.12.2016, 18:22. Показов 1392. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток, делаю фильтрацию по полю "Клиент" в таблице заказов, но есть проблема, при вводе буквы в Edit появляется ошибка "В коллекции не найден элемент соответствующий данному имени или порядковому номеру", буду рад помощи
Вот процедура:
Delphi
1
2
3
4
5
procedure TMainForm.Edit1Change(Sender: TObject);
begin
   DM.TZakaz.Filter:='Клиент >=' + QuotedStr(Edit1.Text);
   DM.TZakaz.Filtered:= True;
end;
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.12.2016, 18:22
Ответы с готовыми решениями:

Фильтрация данных
Помогите пожалуйста. Я не могу отфильтровать данные по дате. Подскажите как правильно написать код .Please

Фильтрация данных
Как отобрать все записи в которых например, поле DATA_V является пустым? Добавлено через 39 секунд Help!!!

Фильтрация данных
База данных Access. Данные отображаются в DBGrid. После фильтрации нужно вывести список (в процентах) полученных строк от общего...

8
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
16.12.2016, 19:11
Если поле Клиент текстового типа, то в условиях фильтра применяют директиву LIKE:
Delphi
1
  DM.TZakaz.Filter:='Клиент LIKE ' + QuotedStr(Edit1.Text+'%');
На будущее: обязательно надо указывать СУБД, с которой идет работа; неплохо будет, если указывать тип полей, участвующих в запросах (фильтрах)
0
1 / 1 / 0
Регистрация: 11.10.2015
Сообщений: 150
16.12.2016, 19:21  [ТС]
спасибо, попробовал с Like, но всё та же ошибка, субд Access
0
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
16.12.2016, 19:38
А есть ли в TZakaz ссылка на это поле вообще?
Перед присвоением строки фильтра хорошо бы вызвать DM.TZakaz.Filtered := False;
Если не поможет, то без проекта и файла базы понять причину проблемы будет сложно.
0
1 / 1 / 0
Регистрация: 11.10.2015
Сообщений: 150
16.12.2016, 19:57  [ТС]
Не получается, вот проект вместе с бд(((
Вложения
Тип файла: zip Учёт заказов автосервиса.zip (454.6 Кб, 4 просмотров)
0
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
16.12.2016, 20:14
Поле Клиент не принадлежит таблице Zakaz, а имеет свойство lookup.
По таким полям локальный фильтр установливать нельзя.
Придется для фильтрации применять SQL запросы.
0
1 / 1 / 0
Регистрация: 11.10.2015
Сообщений: 150
16.12.2016, 20:22  [ТС]
Спасибо большое за помощь, попробовал сделать с датой формирования, оно у меня не подстановочное и текстового типа, но всё рано не получается...
0
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
16.12.2016, 20:31
Лучший ответ Сообщение было отмечено RideRS как решение

Решение

У меня получается, фильтр при вводе символов устанавливается:
Delphi
1
2
3
4
5
6
7
procedure TMainForm.Edit1Change(Sender: TObject);
begin
   DM.TZakaz.Filtered := False;
   if Edit1.Text = '' then Exit;
   DM.TZakaz.Filter := 'Date_form LIKE ' + QuotedStr(Edit1.Text+'%');
   DM.TZakaz.Filtered:= True;
end;
1
1 / 1 / 0
Регистрация: 11.10.2015
Сообщений: 150
16.12.2016, 20:42  [ТС]
Теперь всё получилось, это я просто дурачок, спасибо вам большое
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
16.12.2016, 20:42
Помогаю со студенческими работами здесь

Фильтрация данных
Нужно как то сделать фильтрацию данных одного dbgrid при нажатии на запись во втором dbgrid. таблица Films -это второй dbgrid id_film...

Фильтрация данных
Доброго всем времени! Я в делфи только начинаю работать и столкнулся с такой проблемой, у меня имеется таблица ( MS Access ) в ней 3 поля,...

Фильтрация данных
Не получается сделать фильтрацию данных.

Фильтрация данных
Сделал фильтрацию базы по команде: Select * from tbl where ... Все работает Есть кнопка "Сброс фильтра" Какой командой...

Фильтрация данных
Есть данные ФИО и их пол, нужно отфильтровать Отчество которое не соответствует полу, например: *вич пол женский. Как сделать фильтрацию по...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru