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

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

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

Новые блоги и статьи
Валидация и контроль данных табличной части документа перед записью
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
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru