С Новым годом! Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.78/27: Рейтинг темы: голосов - 27, средняя оценка - 4.78
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 24

Фильтрация в базе данных

13.11.2012, 10:33. Показов 5550. Ответов 30
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите, пожалуйста)
В проекте необходимо осуществить поиск в базе данных программного обеспечения по следующим колонкам: вид ПО, операционная система, фирма-изготовитель и год выпуска.
Лучше сделать с помощью фильтрации, чтобы при вводе какой-то части слова уже происходила фильтрация. Вот проект.
И если не сложно добавьте комметарии, чтобы было понятно.
Вложения
Тип файла: rar DB.rar (649.2 Кб, 60 просмотров)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.11.2012, 10:33
Ответы с готовыми решениями:

Фильтрация и сортировка по числам в базе данных C++
Всем привет! Столкнулся с такой проблемой в базе данных как фильтрация и сортировка, с буквами работает и фильтрпция и сортировка, а вот с...

Фильтрация по полю Group в базе через ADOTable
Как отфильтровать данные в таблице по одному полю Group, если данные для сравнения находятся в переменной типа String, таблица отображается...

Фильтрация в базе данных
привет всем, ситуация следующая. я сделал так скажем базу данных. реализовал я её с помощью таблицы paradox7 и компонентов table,...

30
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
13.11.2012, 12:05
Вот сделал тебе на поле Год остальные думаю догадаешься сам

C++
1
2
3
ADOTable1->Filtered = false;
ADOTable1->Filter = "[Ãîä]="+QuotedStr(Edit4->Text);
ADOTable1->Filtered = true;
2
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 24
13.11.2012, 12:44  [ТС]
Спасибо) Но когда я использую аналогичную конструкцию для других столбцов, фильтрация не работает.
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
13.11.2012, 13:18
Выложи код как ты используешь конструкцию для других полей?
0
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 24
13.11.2012, 14:31  [ТС]
C++
1
2
3
4
5
6
ADOTable1->Filtered = false;
ADOTable1->Filter = "[Год]="+QuotedStr(Edit4->Text);
ADOTable1->Filter = "[Вид ПО]="+QuotedStr(Edit4->Text);
ADOTable1->Filter = "[Операционная система]="+QuotedStr(Edit4->Text);
ADOTable1->Filter = "[Фирма-изготовитель]="+QuotedStr(Edit4->Text);
ADOTable1->Filtered = true;
Добавлено через 10 минут
Edit разные только, исправил

Добавлено через 9 минут
Вот такой вариант в принципе работает.
C++
1
2
3
4
5
6
7
ADOTable1->Filtered = false;
ADOTable1->Filter = "[Ãîä]="+QuotedStr(Edit4->Text);
ADOTable1->Filtered = true;
 
ADOTable1->Filtered = false;
ADOTable1->Filter = "[Âèä ÏÎ] = "+QuotedStr(Edit2->Text);
ADOTable1->Filtered = true;
А как сделать, чтобы фильтрация происходила, когда я в поле вбиваю лишь несколко букв из всего слова?

Добавлено через 33 минуты
А еще как реализовать одновременный поиск по всем полям?
0
 Аватар для Kabak
159 / 145 / 14
Регистрация: 03.02.2012
Сообщений: 788
Записей в блоге: 1
13.11.2012, 15:17
А как сделать, чтобы фильтрация происходила, когда я в поле вбиваю лишь несколко букв из всего слова?

А еще как реализовать одновременный поиск по всем полям?
Пиcать свой обработчик на событие OnFilterRecord в TTable или ADOTable и т.п.
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
13.11.2012, 15:55
Цитата Сообщение от Bunkitut Посмотреть сообщение
А как сделать, чтобы фильтрация происходила, когда я в поле вбиваю лишь несколко букв из всего слова?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
void __fastcall TForm1::Edit1Change(TObject *Sender)
{
if(!Edit1->Text.IsEmpty())
{
 ADOTable1->Filtered = false;
 ADOTable1->Filter = "[Ôèðìà-ñîçäàòåëü] LIKE '"+Edit1->Text+"%'";
 ADOTable1->Filtered = true;
}
else
{
   ADOTable1->Filtered = false;
   ADOTable1->Filter = "";
   ADOTable1->Filtered = true;
}
3
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 24
13.11.2012, 17:37  [ТС]
Спасибо большое) Все отлично работает, я разобрался)
0
75 / 99 / 1
Регистрация: 01.10.2011
Сообщений: 177
16.11.2012, 19:46
чтобы не награмождать edit-ами создай радио кнопку и изначально задай всем эдитам visible->false и радио кнопками включай нужный edit т. е. visible->true
1
 Аватар для Kabak
159 / 145 / 14
Регистрация: 03.02.2012
Сообщений: 788
Записей в блоге: 1
17.11.2012, 02:25
угу, особенно если полей 5 нужно одновременно фильтровать и по нескольким введённым символам Запаришься радиокнопки тискать.
0
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 24
21.11.2012, 15:24  [ТС]
А как сделать фильтрацию одновременно по всем полям?
0
 Аватар для Kabak
159 / 145 / 14
Регистрация: 03.02.2012
Сообщений: 788
Записей в блоге: 1
21.11.2012, 15:53
При изменении каждого причастного к фильтрации Edit обновлять глобальный фильтр базы по всем интересующим полям.
0
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 24
21.11.2012, 19:26  [ТС]
А как сделать одновременную фильтрацию по всем полям Edit?
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
22.11.2012, 00:55
Цитата Сообщение от Bunkitut Посмотреть сообщение
А как сделать одновременную фильтрацию по всем полям Edit?
Сцепить их через AND
0
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 24
24.11.2012, 15:34  [ТС]
а как сцеплять, можете пример показать? уменя ведь 4 поля Edit
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
24.11.2012, 16:07
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
void __fastcall TForm1::Button4Click(TObject *Sender)
{
if(!Edit1->Text.IsEmpty()&&!Edit1->Text.IsEmpty())
{
 ADOTable1->Filtered = false;
 ADOTable1->Filter = "[Îïåðàöèîííàÿ ñèñòåìà] LIKE '"+Edit1->Text+"'AND [Ãîä] LIKE '"+Edit4->Text+"'";
 ADOTable1->Filtered = true;
}
else
{
   ADOTable1->Filtered = false;
   ADOTable1->Filter = "";
   ADOTable1->Filtered = true;
}
И так все остальные
0
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 24
24.11.2012, 16:27  [ТС]
А без кнопки реализовать не получится?

Добавлено через 10 минут
мне нужна динамическая фильтрация по все полям одновременно. такой вариант не работает
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
void __fastcall TForm1::Button4Click(TObject *Sender)
{
if(!Edit1->Text.IsEmpty()&&!Edit1->Text.IsEmpty())
{
 ADOTable1->Filtered = false;
 ADOTable1->Filter = "[Операционная система] LIKE '"+Edit1->Text+"'AND [Год] LIKE '"+Edit4->Text+"'";
 ADOTable1->Filtered = true;
}
else
{
   ADOTable1->Filtered = false;
   ADOTable1->Filter = "";
   ADOTable1->Filtered = true;
}
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
24.11.2012, 16:27
Ну так добавь сам по моему примеру
0
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 24
24.11.2012, 16:28  [ТС]
Я понимаю что в Edit это на пропишешь. Можно в кнопку записать, но чтобы ее нажимать не нужно было
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
24.11.2012, 16:35
прописать в Edit можно, только надо объединить в одну функцию и вызывать потом
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.11.2012, 16:35
Помогаю со студенческими работами здесь

Множественная фильтрация по базе данных
Не могу понять как сделать множественную фильтрацию, есть много способов фильтров, по которым пользователь может выбирать. Допустим пример:...

Сортировка, фильтрация в базе данных
есть база данных по ресторану. мне нужна сортировка по ценам блюд, по названию(по алфавиту), по типу блюд(супы, салаты, ужины и т.д), по...

Фильтрация в базе данных, выдает ошибку
Уважаемые форумчане, доброе утро! Подскажите, пожалуйста, начал делать в базе данных аксесс фильтр, чтоб находил значения по поиску, но в...

Фильтрация записей базе данных в Delphi
Помогите пожалуйста. Я сделал фильтрацию данных в бд, все работает, только при фильтрации из первой бд (ADOTVT) я создал условие при...

Фильтрация, сортировка, поиск в базе данных
меню в базе данных на делфи в которой осуществить фильтрацию,сортировку,поиск(по всем полям).Базу я сделал и связал а как осуществить...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
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 —. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru