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

Фильтрация adoquery

23.06.2019, 20:53. Показов 3762. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Не могу понять, аж злость берет. Пересмотреть ни одну подобную тему, там у людей всё работает. Копирую от туда, подставляю свои значения у меня никакой реакции. Пытаюсь отфильтровать по столбцу где числовые значения. Пробовал и фильтром и через запрос SELECT, ничего не выходит. Никакой реакции абсолютно не происходит.

Пробовал так:
C++
1
ADOQuery1->SQL->Text="SELECT * FROM Electrics WHERE ([Заводской номер] LIKE " + Edit1->Text + ")";
Так:
C++
1
ADOQuery1->Filter = "([Наименование подъемника] LIKE '"+ Edit2->Text + "%')";
Так:
C++
1
ADOQuery1->Filter = "ID <= 10";
Понимаю что ошибка наверняка безумно тупая, но хоть убейте не понимаю в чём дело.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
23.06.2019, 20:53
Ответы с готовыми решениями:

Запрос ADOQuery внутри другого ADOQuery реален?
Помогите сформировать запрос для двух ADOQuery. Есть 2 таблицы БД mssql: sotrudniki , table_hlp(Вспомогательная таблица для делания...

ADOQuery
Друзья! Нужна помощь. Ситуация такая, имеется приложение написанное в билдере ХЕ которое работает с СУБД Оракл. несколько форм, работающие...

ADOQuery
Всем привет, прошу помощи... Делаю запрос в Аксес... Form1-&gt;ADOQuery1-&gt;SQL-&gt;Add(&quot;SELECT * from users where Serial=&quot;+AnsiString(i));...

13
 Аватар для TrollHammer
1216 / 709 / 336
Регистрация: 22.02.2018
Сообщений: 2,095
Записей в блоге: 2
24.06.2019, 00:53
xaochuk, Предикат Like применяется только к строкам!. В последнем варианте:
C++
1
2
ADOQuery1->Filter = "ID <= 10";
ADOQuery1->Filtered = true;
1
Модератор
 Аватар для D1973
9908 / 6445 / 2455
Регистрация: 21.01.2014
Сообщений: 27,354
Записей в блоге: 3
24.06.2019, 09:38
xaochuk, фильтровать запрос? Зачем? Запрос предназначен как раз для того, чтобы Вы получали только нужные данные, ничего не "дорабатывая напильником"...
Цитата Сообщение от xaochuk Посмотреть сообщение
Пробовал так:
ADOQuery1->SQL->Text="SELECT * FROM Electrics WHERE ([Заводской номер] LIKE " + Edit1->Text + ")";
1. Что у Вас в поле [Заводской номер]? Числовые данные или текстовые? Если числовые, то какой может быть LIKE? Если тест - то где обрамляющие кавычки?
2. А вы только текст запроса ввели или выполнить его тоже пытались? Должен был ошибку кинуть, если выполняли... Вот ее и огласите.

Добавлено через 2 минуты
Цитата Сообщение от xaochuk Посмотреть сообщение
Пытаюсь отфильтровать по столбцу где числовые значения
Ага, сразу что-то этого не заметил...
C++
1
2
3
ADOQuery1->Close();
ADOQuery1->SQL->Text="SELECT * FROM Electrics WHERE ([Заводской номер] = " + Edit1->Text + ")";
ADOQuery1->Open();
0
480 / 393 / 113
Регистрация: 24.04.2012
Сообщений: 1,632
Записей в блоге: 3
24.06.2019, 09:52

Не по теме:

Цитата Сообщение от xaochuk Посмотреть сообщение
но хоть убейте не понимаю в чём дело
Давайте его "убьём" :D

1
Модератор
 Аватар для D1973
9908 / 6445 / 2455
Регистрация: 21.01.2014
Сообщений: 27,354
Записей в блоге: 3
24.06.2019, 10:22

Не по теме:

Чтобы не мучился?


1
1 / 1 / 0
Регистрация: 25.04.2019
Сообщений: 43
24.06.2019, 12:45  [ТС]
Все дело и в том что я много вариантов перепробовал, и like, и =, и с ковычками, и без. То что я отправил, это уже конечный вариант, когда я отчаялся. В итоге результат такой, но это общую картину никак не поменяло, всё без измеений ;(

C++
1
2
3
4
5
6
7
8
void __fastcall TForm1::Button3Click(TObject *Sender)
{
ADOQuery1->Close();
ADOQuery1->SQL->Text="SELECT * FROM Electrics WHERE ([Заводской номер] = " + Edit1->Text + ")";
ADOQuery1->Open();
ADOTable1->Active=false;
ADOTable1->Active=true;
}
Добавлено через 6 минут
Если при пустом поле нажать btn3, вылазить ошибка "Лишняя скобка ) в выражении запроса '([Заводской номер] = )', если ввести заведомо имеющийся заводской номер в бд и нажать btn3, то абсолютно никакой реакции
0
480 / 393 / 113
Регистрация: 24.04.2012
Сообщений: 1,632
Записей в блоге: 3
24.06.2019, 13:08
Цитата Сообщение от xaochuk Посмотреть сообщение
ADOTable1->Active=false;
ADOTable1->Active=true;
лишнее.
Цитата Сообщение от xaochuk Посмотреть сообщение
то абсолютно никакой реакции
Уверен?! что здесь
C++
1
ADOQuery1->IsEmpty()
и тут
C++
1
ADOQuery1->RecordCount
?

Добавлено через 51 секунду

Не по теме:

Цитата Сообщение от D1973 Посмотреть сообщение
Чтобы не мучился?
И мы тоже

0
Модератор
 Аватар для D1973
9908 / 6445 / 2455
Регистрация: 21.01.2014
Сообщений: 27,354
Записей в блоге: 3
24.06.2019, 13:50
Цитата Сообщение от xaochuk Посмотреть сообщение
абсолютно никакой реакции
А, кстати, какой реакции Вы ждете? Введите в свой Эдит заведомо существующий номер и выполните вот этот код:
C++
1
2
3
4
ADOQuery1->Close();
ADOQuery1->SQL->Text="SELECT * FROM Electrics WHERE ([Заводской номер] = " + Edit1->Text + ")";
ADOQuery1->Open();
ShowMessage(ADOQuery1->FieldByName("[Наименование подъемника]")->AsString);
что показывает?
0
1 / 1 / 0
Регистрация: 25.04.2019
Сообщений: 43
24.06.2019, 18:08  [ТС]
теперь вообще ничего не понимаю. Вылазит ошибка о том, что такого поля как "наименование подъемника" он не нашёл
0
Модератор
 Аватар для D1973
9908 / 6445 / 2455
Регистрация: 21.01.2014
Сообщений: 27,354
Записей в блоге: 3
24.06.2019, 18:14
А оно есть в таблице Electrics?
0
1 / 1 / 0
Регистрация: 25.04.2019
Сообщений: 43
24.06.2019, 20:33  [ТС]
Если я всё правильно понял. После выполнения sql запроса, проверил
C++
1
ADOQuery1->IsEmpty()
условным оператором if, и там что было. В
C#
1
ADOQuery1->RecordCount
записалось значение "2", то есть количество строк соответствующих этому заводскому номеру.

Добавлено через 28 секунд
да, оно есть в каждой таблице

Добавлено через 2 часа 17 минут
Сообщение о том, что поле не найдено пропало, и стал приходить адекватный ответ. Надо было убрать квадратные скобки.

C++
1
ShowMessage(ADOQuery1->FieldByName("Наименование подъемника")->AsString);
Осталось разобраться, как теперь сделать чтобы в DBGrid оставались только строки обработанные фильтрацией
0
480 / 393 / 113
Регистрация: 24.04.2012
Сообщений: 1,632
Записей в блоге: 3
25.06.2019, 03:22
Цитата Сообщение от xaochuk Посмотреть сообщение
Осталось разобраться, как теперь сделать чтобы в DBGrid оставались только строки обработанные фильтрацией
DBGrid->DataSource->DataSet != ADOQuery1 ??

Не по теме:

Может всё таки прикончим его?!!

0
1 / 1 / 0
Регистрация: 25.04.2019
Сообщений: 43
25.06.2019, 12:38  [ТС]
К своему стыду я не понял, что вы хотели сказать этой строчкой Поэтому обошёлся просто фильтрацией.

C++
1
2
ADOQuery1->DataSource->DataSet->Filter = "ID >= 11";
ADOQuery1->DataSource->DataSet->Filtered=true;
Хоть как то фильтровать стало. Пойдёт. Видимо я ещё совсем глуп для реализации того, чего хотел Всем спасибо за помощь.
0
Модератор
 Аватар для D1973
9908 / 6445 / 2455
Регистрация: 21.01.2014
Сообщений: 27,354
Записей в блоге: 3
25.06.2019, 18:35

Не по теме:

Цитата Сообщение от Bit_Man Посмотреть сообщение
Может всё таки прикончим его?!!
Да, пожалуй что проще будет...


xaochuk, от Вас нет никаких данных о структуре таблицы, о том, на основе какого набора данных работает Ваш DBGrid - ну ничегошеньки... И что Вы хотите услышать в ответ-то???
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.06.2019, 18:35
Помогаю со студенческими работами здесь

ADOQuery
ADOQuery при попытке сделать его активным выдает ошибку &quot;Missing SQL property&quot;. Источник для ADOQuery ADOConnection. Он подключился...

ADOQuery+ComboBox
Пытаюсь заполнить ComboBox с помощью ADOQuerу, не получается. Почему то пишет что поле &quot;ID&quot; не найдено, хотя оно есть. ...

ADOQuery параметры
ADOQuery3-&gt;Active = false; ADOQuery3-&gt;SQL-&gt;Clear(); ADOQuery3-&gt;SQL-&gt;Add(&quot;SELECT ФИО, Компания, Дата1, Дата2, Причина&quot;); ...

Поиск в ADOQuery
Здравствуйте! Подскажите пожалуйста как сделать поиск в ADOQuery, с категориями(они находятся в combobox). Я пробую так: if...

Вывод из ADOQuery
Добрый вечер.Такая проблемка возникла.Необходимо вывести в ComboBox выборку из базы данных. Запрос на выборку из таблицы выглядит так ...


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
Учёным и волонтёрам проекта «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. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru