Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
15 / 15 / 0
Регистрация: 22.06.2018
Сообщений: 199

Создание сложного фильтра в Базах данных из Delphi

18.11.2018, 21:48. Показов 1241. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!

Есть База данных на SQL. Хотел сделать фильтрацию по двум полям , но , к сожалению, идет только по одному полю ,а по -другому пишет ошибку: Аргументы имеют неверный тип...
Само поле Used - целое. Думал просто преобразовать его к строке и сравнить с 0-м. Сравнение просто целого Used c нулем
тоже ничего не дает.

Delphi
1
2
3
4
5
6
 Connecting_to_DataBase.DataModule1.Table_of_task.Filtered:=false;
         Connecting_to_DataBase.DataModule1.Table_of_task.Filter:=('Rating>'
         +IntToStr(Connecting_to_DataBase.DataModule1.Table_of_task.FieldByName('Rating').AsInteger))
         [U]+IntToStr(Connecting_to_DataBase.DataModule1.Table_of_task.FieldByName('Used').AsInteger)+
        '='+'0';[/U];
Connecting_to_DataBase.DataModule1.Table_of_task.Filtered:=true;

Просьба, пожалуйста, помочь составить запрос по двум полям.
.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.11.2018, 21:48
Ответы с готовыми решениями:

Delphi! База Данных ClientDataSet, создание фильтра (запроса) с текущим временем?
Как создать фильтр, напр. "ВЫБЕРИ ВСЕ ЗАПИСИ У КОТОРЫХ ПОЛЕ VREMA БОЛЬШЕ ЧЕМ ТЕКУЩЕЕ ВРЕМЯ" rTime:=Time; // текущее время ...

Построение сложного фильтра
Всем доброго времени суток. Возникла необходимость построения фильтра вида: "SEC = '"+sec+"' AND OBH = '"+obh+"'...

Обновление одних и тех-же данных в двух базах данных
Всем здрасте, как варианты есть для того чтобы обновить данные на двух серверах сразу тоесть когда попадают данные в одну базу данных их-же...

6
5971 / 4547 / 1094
Регистрация: 29.08.2013
Сообщений: 28,168
Записей в блоге: 3
19.11.2018, 08:54
а ты сделай
Delphi
1
Showmessage(Connecting_to_DataBase.DataModule1.Table_of_task.Filter);
перед
Delphi
1
Connecting_to_DataBase.DataModule1.Table_of_task.Filtered:=true;
и посмотри что у тебя не так
0
15 / 15 / 0
Регистрация: 22.06.2018
Сообщений: 199
19.11.2018, 13:27  [ТС]
Ок, да, получилось так, что вместо двух разных запросов Delphi
выдает Rating>31=0 (см. приложенный файл).
А после этого Delphi выдает ошибку, которую видим в первом файле, приложенном выше.
Но тут иное получается, что Delphi видит оба поля , но не фильтрует их, так как не распознает, как два разных поля .
Т.е. должно быть ,например , так (Rating>3) AND (Used=0) а вместо этого он распознает, как Rating>31=0.
А как сделать именно (Rating>3) AND (Used=0) типа такого.

Можете, пожалуйста, подсказать?
0
Модератор
 Аватар для D1973
9921 / 6457 / 2457
Регистрация: 21.01.2014
Сообщений: 27,404
Записей в блоге: 3
19.11.2018, 13:51
Да так и сделать, как написали... А еще лучше не Table фильтровать, а использовать Query с SQL-запросами...
0
15 / 15 / 0
Регистрация: 22.06.2018
Сообщений: 199
19.11.2018, 15:23  [ТС]
ДА, Вы правы, and и прочие логические операторы не работают в фильтрации БД! Пример тому подтверждение - см. файл. и ниже.

Delphi
1
2
3
4
5
6
Connecting_to_DataBase.DataModule1.Table_of_task.Filtered:=false;
         Connecting_to_DataBase.DataModule1.Table_of_task.Filter:=('(Rating>'
         +IntToStr(Connecting_to_DataBase.DataModule1.Table_of_task.FieldByName('Rating').AsInteger))       
         +')AND('
        +IntToStr(Connecting_to_DataBase.DataModule1.Table_of_task.FieldByName('Used').AsInteger)+
          '='+'0)';
0
5971 / 4547 / 1094
Регистрация: 29.08.2013
Сообщений: 28,168
Записей в блоге: 3
19.11.2018, 15:34
Цитата Сообщение от Alexey-PK Посмотреть сообщение
Вы правы, and и прочие логические операторы не работают в фильтрации БД
все работает

Цитата Сообщение от Alexey-PK Посмотреть сообщение
Пример тому подтверждение - см. файл. и ниже.
ты просто не умеешь его готовить

почувствуй разницу
Delphi
1
2
s:=')AND(';
s:=') AND (';
1
Модератор
 Аватар для D1973
9921 / 6457 / 2457
Регистрация: 21.01.2014
Сообщений: 27,404
Записей в блоге: 3
19.11.2018, 18:47
Лучший ответ Сообщение было отмечено Alexey-PK как решение

Решение

Вам самому не кажется что вот эта часть условия - ntToStr(Connecting_to_DataBase.DataModul e1.Table_of_task.FieldByName('Used').AsI nteger)+'='+'0)'; - просто чушь?
Delphi
1
2
3
4
5
6
with Connecting_to_DataBase.DataModule1.Table_of_task do
 begin
  Filtered:=false;
  Filter:= Format('(Rating > %d) AND (Used = 0)', [FieldByName('Rating').AsInteger]);
  Filtered:=true;
 end;
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.11.2018, 18:47
Помогаю со студенческими работами здесь

Способы хранения данных в реляционных базах данных
Здравствуйте. Есть заполненная таблица в БД. После загрузки данных в базу требуется выполнить следующие запросы для каждого способа...

Исключения в базах данных
Подскажите пожалуйста, необходимо ответить на вопрос по SQL. Всё что искал - не подходит. Исключения и что. Создание исключения...

Даты в Базах Данных
Доброго времени суток. Вопросы ко всем кто использует Базы данных в своих программах. Они многим покажутся смешными.. но все же :-) ...

Ошибка в Базах Данных
Ребят помогите пожалуйста: //Программа работы с базой данных "Экскурсии" //Создание базы //Просмотр базы //Поиск по названию...

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


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru