Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/30: Рейтинг темы: голосов - 30, средняя оценка - 4.73
1 / 1 / 0
Регистрация: 19.02.2010
Сообщений: 26

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

19.02.2010, 22:02. Показов 6267. Ответов 16
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Возник вопрос, точнее критическая проблема)
Вроде все было понятно, начал делать и запутался так, что теперь вообще ничего не понятно...
Есть таблица: Число, Месяц, Год... Нужно написать обработчик кнопки, который будет фильтровать сразу по этим трем колонкам, беря инфо с трех эдитов
Короче обработчик пока работает только с первым эдитом (числом)
C++
1
Form1->Table1->Filter=(AnsiString("[Число]=")+(Edit1->Text));
Как сюда же дописать и остальные два эдита? Помогите пожалуйста, запутался конкретно, ничего не выходит!
1
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.02.2010, 22:02
Ответы с готовыми решениями:

фильтрация таблицы по DBCheckBox
вот такой вопрос: у меня есть таблица, которую я сформировала с помощью запроса. теперь я хочу отфильтровать эту таблицу. Она имеет поле...

Синхронизация столбца в DBGrid и ComboBox и фильтрация таблицы
Подскажите пожалуйста, есть таблица, в ней столбец "Категория" (1) и есть "ComboBox" (2): 1. как сделать так, чтобы при добавлении какой...

Фильтрация из нескольких столбцов таблицы по нескольким условиям!
Всех приветствую! Имеется файл MS Access, в нем таблица с 10-ю столбцами. Обращение к таблице через ADOTable. Искомое значение вводим...

16
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
20.02.2010, 10:50
sergei_exe, а в чем проблема? через and / or (в зависимости от условия) написать не можешь? тем более, что остальные условия пишутся по аналогии с первым
0
1 / 1 / 0
Регистрация: 19.02.2010
Сообщений: 26
20.02.2010, 11:26  [ТС]
Цитата Сообщение от Lord_Voodoo Посмотреть сообщение
sergei_exe, а в чем проблема? через and / or (в зависимости от условия) написать не можешь? тем более, что остальные условия пишутся по аналогии с первым
Если бы там были конкретные данные, уже написал бы. А т.к. они считываются с эдитов, и с этим AnsiString, у меня не получается. Не пойму принципа и все)
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
20.02.2010, 11:31
это катит при обязательном заполнении всех эдитов, в противном случае, надо ставить проверки
C++
1
Form1->Table1->Filter="field1 = "+Edit1->Text + " and field2 = " + Edit2->Text + " and field3 =" Edit3->Text;
Добавлено через 35 секунд
что вы понимаете под корректными данными?
0
1 / 1 / 0
Регистрация: 19.02.2010
Сообщений: 26
20.02.2010, 13:49  [ТС]
Цитата Сообщение от Lord_Voodoo Посмотреть сообщение
это катит при обязательном заполнении всех эдитов, в противном случае, надо ставить проверки
C++
1
Form1->Table1->Filter="field1 = "+Edit1->Text + " and field2 = " + Edit2->Text + " and field3 =" Edit3->Text;
Добавлено через 35 секунд
что вы понимаете под корректными данными?
Не "корректными", а конкретными. Я имел в виду, что если написать к примеру:
C++
1
Form1->Table1->Filter="([Число]=22)and("[Месяц]=Февраль")and([Год]=2010)";
То естественно он выдаст данные только по 22.02.2010. А суть заключается в том, что бы число, месяц и год пользователь указывал в эдиты. Вот и проблема в самом обработчике, из-за которого я не могу сдвинуться с места. Знания не на столько велики, на уровене учебной программы + логика, которая к сожалению не всегда сробатывает) Перечитал Архангельского по поводу фильтрации, похожего случая не нашел, и в инете тоже не попаду
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
21.02.2010, 12:02
sergei_exe, а вам не проще поставить компонент TDateTimePicker?? Потом данные, которые выставит пользак, конвертировать в строку и резать на число, месяц и год? И тебе проще и пользаку удобнее
0
1 / 1 / 0
Регистрация: 19.02.2010
Сообщений: 26
21.02.2010, 14:25  [ТС]
Цитата Сообщение от Lord_Voodoo Посмотреть сообщение
sergei_exe, а вам не проще поставить компонент TDateTimePicker?? Потом данные, которые выставит пользак, конвертировать в строку и резать на число, месяц и год? И тебе проще и пользаку удобнее
Да с этим ладно, переворотил половину кода и решил проблему. Теперь посыпались проблемы с условиями. Уже сил нет с этим курсовиком...

Сначала было такое условия для смены таблиц выбором из комбобокса:
C++
1
2
3
4
5
if("Form2->ComboBox3->Text=Запад") Form2->Table1->TableName="Запад";
if("Form2->ComboBox3->Text=Восток") Form2->Table1->TableName="Восток";
if("Form2->ComboBox3->Text=Восток-Центр") Form2->Table1->TableName="Восток-Центр";
if("Form2->ComboBox3->Text=Центр") Form2->Table1->TableName="Центр";
if("Form2->ComboBox3->Text=Юг") Form2->Table1->TableName="Юг";
Все отлично работало, но по каким-то причинама, неизвестным мне, перестало. Я написал так:
C++
1
2
3
4
5
6
7
8
9
10
if (AnsiString(Form2->ComboBox3->Text).AnsiCompareIC("Запад") == 0)
      Form2->Table1->TableName="Запад";
else { if (AnsiString(Form2->ComboBox3->Text).AnsiCompareIC("Центр") == 0)
Form2->Table1->TableName="Центр";
else { if (AnsiString(Form2->ComboBox3->Text).AnsiCompareIC("Восток") == 0)
Form2->Table1->TableName="Восток";
else { if (AnsiString(Form2->ComboBox3->Text).AnsiCompareIC("Восток-Центр") == 0)
Form2->Table1->TableName="Восток-Центр";
else {if (AnsiString(Form2->ComboBox3->Text).AnsiCompareIC("Юг") == 0)
Form2->Table1->TableName="Юг";  }}}}
Все работает только с первого раза. При следущей попытке выдаешт ошибку.

И с этим условием запара:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
if ("Form1->DBEdit6->Text==Ясно")
       {Image12->Visible=true;
       Image13->Visible=false;
       Image14->Visible=false;
       Image15->Visible=false;}
 
else {if ("Form1->DBEdit6->Text==Облачно")
       {Image12->Visible=false;
       Image13->Visible=true;
       Image14->Visible=false;
       Image15->Visible=false;}
 
else  {if ("Form1->DBEdit6->Text=Дождь")
       {Image12->Visible=false;
       Image13->Visible=false;
       Image14->Visible=true;
       Image15->Visible=false;}
 
else {if ("Form1->DBEdit6->Text=Снег")
       {Image12->Visible=false;
       Image13->Visible=false;
       Image14->Visible=false;
       Image15->Visible=true; } } }}
Выдает только Image12->Visible=true;, остальные условия не воспринимает.
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
22.02.2010, 10:26
sergei_exe, если у вас данные в комбике и так нужные, зачем вообще эти проверки? Нужна максимум одна - ItemIndex != -1, тобишь что-то пользователь все же выбрал...
"Form1->DBEdit6->Text==Ясно" - это вообще странные условия, тут кавычки не нужны, а выполняется первое условие, только потому, что строка непустая, а следовательно, условие будет верным
Надо так:
Form1->DBEdit6->Text=="Ясно"
0
 Аватар для Airhand
537 / 459 / 3
Регистрация: 08.07.2009
Сообщений: 2,625
22.02.2010, 10:28
Что значит
if ("Form1->DBEdit6->Text==Ясно")
?
Оно сравнивает строку в ифе с нулём, и если она не равна нулю, то выполняет слелующий за ифом блок.
0
1 / 1 / 0
Регистрация: 19.02.2010
Сообщений: 26
22.02.2010, 19:29  [ТС]
sergei_exe, если у вас данные в комбике и так нужные, зачем вообще эти проверки? Нужна максимум одна - ItemIndex != -1, тобишь что-то пользователь все же выбрал...
"Form1->DBEdit6->Text==Ясно" - это вообще странные условия, тут кавычки не нужны, а выполняется первое условие, только потому, что строка непустая, а следовательно, условие будет верным
Надо так:
Form1->DBEdit6->Text=="Ясно"
Уже совсем разобрался и показал преподавателю, все устраивает)
Оно сравнивает строку в ифе с нулём, и если она не равна нулю, то выполняет слелующий за ифом блок.
Сейчас поясню...
В таблице содержатся данные о погоде. После фильтрации остается одна дата, следовательно одна строка в таблице. Каждая графа выдает информацию (температуру, давление, скорость ветра и т.п.) в соответствующие дбэдиты. В таблице есть графа "Осадки". Мне кажется, что куда лучше будет смотреться изображение, чем надпись... Поэтому в зависимости от надписи в дбэдите6 (который скрыт) отображается то или иное изображение. Конечно куда логичнее было бы обращаться к самой графе в таблице, нежели выводить инфо в дбэдит, а с него считывать, но я узнал про С++ только осенью и еще очень многого не знаю. Как ума хватило реализовать, так и реализовал))
0
 Аватар для Airhand
537 / 459 / 3
Регистрация: 08.07.2009
Сообщений: 2,625
23.02.2010, 00:05
Всё дело в том, как сказал уже Lord_Voodoo в том, что строка "Form1->DBEdit6->Text==Ясно" никогда не равна нулю, поэтому оно всё время выполняет первый блок. Надо сделать так, как сказалLord_Voodoo или использовать специальную функцию сравнения строк.
0
1 / 1 / 0
Регистрация: 19.02.2010
Сообщений: 26
23.02.2010, 00:38  [ТС]
Спасибо. Все уже готово!
Остается только вывод на печать, расчет минимума и максимума и построение графика температер за период времени (что мне кажется будет сложнова-то).

А вот вопрос чисто ради интереса: Программу пушу используя BDE Administrator. То есть он является посредником между программай и БД, без него никак. Вообще получается глупо: при отсутствии БДЕ администратора программа неработоспособна... А вот с ADO еще не работал, и понятия о нем не имею. Будет ли функцианировать программа без каких либо "посредников"?
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
23.02.2010, 09:07
sergei_exe, можно опытным путем отобрать набор библиотек в БДЕ, тогда установка БДЕ не нужна будет... простым является использование Firebird - для его работы достаточно одной библиотеки
0
 Аватар для Airhand
537 / 459 / 3
Регистрация: 08.07.2009
Сообщений: 2,625
23.02.2010, 11:31
Через ADO можно, понадобится только 3 длл за собой таскать.
0
1 / 1 / 0
Регистрация: 19.02.2010
Сообщений: 26
23.02.2010, 16:56  [ТС]
Цитата Сообщение от Airhand Посмотреть сообщение
Через ADO можно, понадобится только 3 длл за собой таскать.
Ну так это куда лучше, чем ставить БДЕ. Надо будет в это вникнуть лучше)

А насчет Firebird читал, что прийдется ставить и запускать сервак?!
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
24.02.2010, 11:26
sergei_exe, нет, нужна Gds32.dll и база, этого вполне хватит
0
1 / 1 / 0
Регистрация: 19.02.2010
Сообщений: 26
24.02.2010, 15:30  [ТС]
Ну и хорошо)) Сделаю курсовик, поковыряюсь с этим)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.02.2010, 15:30
Помогаю со студенческими работами здесь

Фильтрация данных
Помогите разобраться с фильтрацией по числовому полю. Вот с текстовыми полями проблем нету. А тут не знаю как правильно в типы перевести и...

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

Фильтрация в базе данных
Помогите, пожалуйста) В проекте необходимо осуществить поиск в базе данных программного обеспечения по следующим колонкам: вид ПО,...

Фильтрация данных ADOTable
Мне нужно отфильтровать данные по 2 значениям, но выскакивает ошибка: "Аргументы имеют неверный тип, выходят за пределы допустимого...

ADOTable, фильтрация данных
Ребята подскажите пожалуйста с фильтрацией данныхADOTable1->Locate("Название столбца", Edit1->Text, /*Вот здесь вся проблема как не...


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

Или воспользуйтесь поиском по форуму:
17
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru