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

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

13.11.2012, 10:33. Показов 5541. Ответов 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
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 24
24.11.2012, 16:42  [ТС]
Студворк — интернет-сервис помощи студентам
В каждом Edite функцию вызывать?
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
24.11.2012, 17:07
Да именно так
0
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 24
24.11.2012, 17:33  [ТС]
Я сделал так:
Написал функцию фильтрации
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
void __fastcall TForm1::Filtration()
{
  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;
}
}
Вызываю ее в каждом Edit:
C++
1
2
3
4
5
6
7
8
void __fastcall TForm1::Edit4Change(TObject *Sender)
{
  Filtration();
void __fastcall TForm1::Edit1Change(TObject *Sender)
{
 Filtration();
}
}
Но фильтрация не работает
0
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 24
24.11.2012, 17:38  [ТС]
вот проект
Вложения
Тип файла: rar DB.rar (708.4 Кб, 9 просмотров)
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
24.11.2012, 22:37
А так пробуй?
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
if(!Edit1->Text.IsEmpty()&&!Edit4->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, 23:25  [ТС]
не работает
0
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 24
25.11.2012, 11:34  [ТС]
Как сделать функцию динамической фильтрации по 4 полям Edit одновременно? в такой бд
Вложения
Тип файла: rar DB.rar (690.4 Кб, 8 просмотров)
0
 Аватар для Kabak
159 / 145 / 14
Регистрация: 03.02.2012
Сообщений: 788
Записей в блоге: 1
25.11.2012, 20:08
OnFilterRecord
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
25.11.2012, 21:50
А кчему бы просто не воспользоваться объектом ADOQuery?
0
480 / 393 / 113
Регистрация: 24.04.2012
Сообщений: 1,632
Записей в блоге: 3
26.11.2012, 03:33
Добавлено через 1 минуту
Цитата Сообщение от Sasha Посмотреть сообщение
if(!Edit1->Text.IsEmpty()&&!Edit4->Text.IsEmpty())
может лучше по отдельности проверять и добавлять в фильтр

Добавлено через 5 минут
Как нибудь так:
C++
1
2
3
4
5
6
7
8
9
10
if (ADOTable1->Filtered) ADOTable1->Filtered = false;
ADOTable1->Filter = "";
if(!Edit1->Text.IsEmpty())  
 ADOTable1->Filter = "[Операционная система] LIKE " + QuotedStr(Edit1->Text); 
if (!Edit4->Text.IsEmpty())
 { 
  if (!ADOTable1->Filter.IsEmpty()) ADOTable1->Filter += " AND ";
  ADOTable1->Filter += "[Год] LIKE " + QuotedStr(Edit4->Text); 
 }
if (!ADOTable1->Filter.IsEmpty()) ADOTable1->Filtered = true;
Добавлено через 6 минут
Кстати у тебя вместо
SQL
1
LIKE
можно и
SQL
1
=
поставить, а если нужно найти вхождение то лучше
C++
1
"Like '%"+ Edit1->Text + "%'"
0
0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 24
27.11.2012, 09:28  [ТС]
я сделал функцию фильтрации вот таким образом:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
void __fastcall TForm1::Filtration(AnsiString nameRow, TEdit *Sender)
{
  if(!Sender->Text.IsEmpty()){
    ADOTable1->Filtered = false;
    ADOTable1->Filter = "["+nameRow+"] LIKE '"+Sender->Text.Trim()+"%'";
    ADOTable1->Filtered = true;
  }
  else {
    ADOTable1->Filtered = false;
    ADOTable1->Filter = "";
    ADOTable1->Filtered = true;
  }
}
И затем изменяю параметры функции при фильтрации полей, в принципе все работает.
C++
1
2
3
4
5
//фильтрация по полю "Операционная система"
void __fastcall TForm1::Edit1Change(TObject *Sender)
{
Filtration("Операционная система", (TEdit*)Sender);
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.11.2012, 09:28
Помогаю со студенческими работами здесь

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

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
31
Ответ Создать тему
Новые блоги и статьи
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
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. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru