0 / 0 / 0
Регистрация: 13.11.2012
Сообщений: 24

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

13.11.2012, 10:33. Показов 5687. Ответов 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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru