Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.85/13: Рейтинг темы: голосов - 13, средняя оценка - 4.85
 Аватар для jkrnd
179 / 69 / 13
Регистрация: 22.12.2015
Сообщений: 2,648

Сформировать запрос и отобразить его результат в DBGrid

19.06.2019, 16:22. Показов 2873. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем здравствуйте.

При старте программы в DBGrid1 заносятся все записи из таблицы <telefon> базы данных <tel.mdb>, одно из полей таблицы имеет имя <Name> (строка):
C++
1
2
3
4
5
6
7
8
9
10
11
void __fastcall TForm1::FormCreate(TObject *Sender)
{
    const String ConnStr = "Provider=%s;Data Source=%s;Mode=%s";
    ADOConnection1->LoginPrompt = false;
    ADOConnection1->ConnectionString = Format (ConnStr, ARRAYOFCONST(("Microsoft.Jet.OLEDB.4.0","tel.mdb", "Share Deny None")));
    ADOQuery1->Connection = ADOConnection1;
    ADOQuery1->SQL->Add("SELECT * FROM [telefon]");
    ADOQuery1->Active = true;
    DataSource1->DataSet = ADOQuery1;
    DBGrid1->DataSource = DataSource1;
}
На форме в Edit1 введён текст с русской буквой 'а'.
Нужно вывести в DBGrid1 только те записи у которых в поле <Name> есть, текст отображённый в Edit1:
C++
1
2
3
4
5
6
7
8
9
void __fastcall TForm1::Button1Click(TObject *Sender)
{
    AnsiString query;
    query = "SELECT * FROM [telefon] WHERE Name LIKE '%+Edit1->Text+%'";
    ADOConnection1->Open();         // Открыли запрос
    ADOQuery1->SQL->Clear();        // Очистили текст запроса
    ADOQuery1->SQL->Add(query);     // Добавили текст запроса
    ADOQuery1->ExecSQL();           // Отправили на выполнение
}
Ничего не происходит. DBGrid1 просто очищается. Разумеется записи, удовлетворяющие нашему условию отбора в таблице есть.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.06.2019, 16:22
Ответы с готовыми решениями:

Отобразить результат выполнения запроса в DbGrid
Здравствуйте, подскажите пожалуйста, как сделать, чтобы в DBGrid отобразил результаты выполнения запроса..

Запросы: для выбранного в DBGrid сотрудника отобразить информацию в другом DBGrid
Добрый вечер! Вот какой вопрос необходимо для выбранного сотрудника в DBGrid отобразить информацию в другом DBGrid допустим об образовании....

Какой запрос отослать серверу, что бы получить PDF и отобразить его на всю страницу?
Привет! Я нуб в HTML :D Web сервер пишу свой на С++. Что мне нужно из HTML отправить серверу для запроса PDF-ки из какой-то серверной...

9
Модератор
 Аватар для D1973
9924 / 6460 / 2457
Регистрация: 21.01.2014
Сообщений: 27,411
Записей в блоге: 3
19.06.2019, 17:12
Лучший ответ Сообщение было отмечено jkrnd как решение

Решение

Цитата Сообщение от jkrnd Посмотреть сообщение
Ничего не происходит.
Давайте разберем построчно...
Цитата Сообщение от jkrnd Посмотреть сообщение
AnsiString query;
query = "SELECT * FROM [telefon] WHERE Name LIKE '%+Edit1->Text+%'";
Во первых - не обязательно две строки, во вторых - у Вас ошибка работы со строками
Цитата Сообщение от jkrnd Посмотреть сообщение
ADOConnection1->Open(); // Открыли запрос
Нет! Это Вы установили соединение с БД. А это делается, как правило один раз при старте программы
Цитата Сообщение от jkrnd Посмотреть сообщение
ADOQuery1->SQL->Clear(); // Очистили текст запроса
ADOQuery1->SQL->Add(query); // Добавили текст запроса
Нет! Совершенно не нужное действие. Если использовать свойство Text - тогда текст запроса будет заменяться полностью без лишней очистки.
Цитата Сообщение от jkrnd Посмотреть сообщение
ADOQuery1->ExecSQL(); // Отправили на выполнение
Нет! Метод ExecSQL() вызывается в том случае, если запрос не возвращает никаких данных, т.е. в случае добавления, изменения и удаления данных. В случае же выборки используется метод Open()
И прежде, чем менять текст запроса - его закрыть нужно.
В итоге получится:
C++
1
2
3
4
ADOQuery1->Close();
String query = "SELECT * FROM telefon WHERE Name LIKE '%" + Edit1->Text + "%'";
ADOQuery1->SQL->Text = query;
ADOQuery1->Open();
1
 Аватар для jkrnd
179 / 69 / 13
Регистрация: 22.12.2015
Сообщений: 2,648
19.06.2019, 17:22  [ТС]
D1973, не подскажете литературу, где об сих действиях можно почитать. Хотелось бы познакомиться с ADO. Например, что означает запись '%"....."%'. Ведь код, который я описал в своём вопросе я нарыл в интернете, а он оказался кривой
0
Модератор
 Аватар для D1973
9924 / 6460 / 2457
Регистрация: 21.01.2014
Сообщений: 27,411
Записей в блоге: 3
19.06.2019, 18:12
Цитата Сообщение от jkrnd Посмотреть сообщение
что означает запись '%"....."%'
Ну эта запись просто вырвана из контекста... Вот смотрите:
у нас есть запрос (кстати, при использовании однословной латиницы в наименовании таблиц и полей квадратные скобки можно не использовать, если это наименование не является зарезервированным словом в Access):
SQL
1
SELECT * FROM telefon
Это означает, что необходимо выбрать все записи из таблицы telefon.
Если вы хотите ограничить критерий отбора - используетcя конструкция WHERE, где прописывается условие отбора. Например:
SQL
1
SELECT * FROM telefon WHERE Name = 'Вася'
Тут будут отобраны только те записи, для которых поле Name равно значению Вася. Тут важный момент: если тип поля, по которому ведется отбор, текстовый - значение должно быть обрамлено одинарными кавычками (но это - конкретно для Access. для других СУБД могут использоваться другие ограничители, ` в MySQL, например...), если значение числовое - обрамление кавычками не требуется:
SQL
1
SELECT * FROM telefon WHERE ID = 1
но все это - это отбор по точному совпадению. Если же Вам требуется отбор по частичному совпадению - используется конструкция LIKE. Важным моментом является то, что LIKE применяется только к текстовым полям!!!
Примеры: (таблица содержит 3 записи, в поле Name значения "Иван", "Анна", "панк")
SQL
1
SELECT * FROM telefon WHERE Name LIKE '%ан%'
Отбираются записи, содержащие в поле Name буквосочетание "ан" (Иван, Анна, панк - регистр, по умолчанию, в Access не важен)
SQL
1
SELECT * FROM telefon WHERE Name LIKE 'ан%'
Отбираются записи, начинающиеся с буквосочетания "ан" в поле Name (Анна)
SQL
1
SELECT * FROM telefon WHERE Name LIKE '%ан'
Отбираются записи, заканчивающиеся на буквосочетания "ан" в поле Name (Иван)
Теперь о том, как использовать это дело в своей программе. Пусть Вы вводите нужный критерий отбора в поле ввода Edit1. Тут просто надо помнить, что запросы выполняются посредством компонента ASDOQuery, а свойство SQL->Text этого компонента - ни что иное, как строка типа String. Вот мы и формируем этот запрос посредством конкатенации строк (Edit1->Text - это тоже тот же самый String)
C++
1
String query = "SELECT * FROM telefon WHERE Name LIKE '%" + Edit1->Text + "%'";
либо посредством строки форматирования
C++
1
String query = String().sprints(L"SELECT * FROM telefon WHERE Name LIKE '%%%s%%'", Edit1->Text);
В любом случае Вы можете, при отладке, посмотреть окончательный вариант своего сформированного запроса, прежде чем его выполнять:
C++
1
ShowMessage(ADOQuery1->SQL->Text);
Но правильней всего - генерировать и отлаживать запрос в самой СУБД и только после того, как он будет безошибочно работать - переносить текст этого запроса в свою программу.
Цитата Сообщение от jkrnd Посмотреть сообщение
где об сих действиях можно почитать.
Работа с ADO - у Архангельского более чем нормально раскрыта, а язык SQL - ну тут тоже куча книг, только надо учитывать, что для каждой конкретной СУБД существуют некоторые нюансы, присущие только этой СУБД...
1
20.06.2019, 03:42

Не по теме:

Цитата Сообщение от D1973 Посмотреть сообщение
Совершенно не нужное действие
Цитата Сообщение от D1973 Посмотреть сообщение
String query
Совершенно не нужная переменная :D (сарказм)

0
Модератор
 Аватар для D1973
9924 / 6460 / 2457
Регистрация: 21.01.2014
Сообщений: 27,411
Записей в блоге: 3
20.06.2019, 04:01
Цитата Сообщение от Bit_Man Посмотреть сообщение
Совершенно не нужная переменная
В данном конкретном примере - да, конечно, в общем и целом - не согласен... Зачастую запрос формируется не по одному полю и не по одной таблице, с предварительным анализом передаваемых в запрос данных и т.д. и т.п. В этом случае куда как проще оперировать со строковой переменной, чем постоянно дозаписывать свойство SQL->Text
1
 Аватар для jkrnd
179 / 69 / 13
Регистрация: 22.12.2015
Сообщений: 2,648
20.06.2019, 06:28  [ТС]
D1973, если я хочу искать совпадения и делать выборку по всем полям таблицы, я должен перечислить каждое из полей через OR? Или можно как-то укоротить запрос?
SQL
1
2
3
OR Name LIKE  '...'
OR Address LIKE  '...'
OR Rem LIKE '...'
А как вывести все записи с сортировкой по возрастанию по полю Name? По убыванию по полю Name?
0
 Аватар для TrollHammer
1216 / 709 / 336
Регистрация: 22.02.2018
Сообщений: 2,095
Записей в блоге: 2
20.06.2019, 06:42
Цитата Сообщение от jkrnd Посмотреть сообщение
по всем полям таблицы,
Тогда не OR а AND
Цитата Сообщение от jkrnd Посмотреть сообщение
возрастанию по полю Name
T-SQL
1
Order By [Name] ASC
Цитата Сообщение от jkrnd Посмотреть сообщение
По убыванию по полю Name
T-SQL
1
Order By [Name] DESC
Добавлено через 4 минуты
jkrnd, Кстати, хорошая практика - создавать запросы непосредственно в БД, там их отлаживать, а уже потом переносить в код. Меньше проблем с ошибками.

Добавлено через 2 минуты
jkrnd, Access SQL https://support.office.com/ru-... dc3e460671
1
Модератор
 Аватар для D1973
9924 / 6460 / 2457
Регистрация: 21.01.2014
Сообщений: 27,411
Записей в блоге: 3
20.06.2019, 07:08
Цитата Сообщение от TrollHammer Посмотреть сообщение
Тогда не OR а AND
При AND у Вас искомое значение должно будет находиться во всех полях одновременно... Так что в данной ситуации - только OR
Цитата Сообщение от jkrnd Посмотреть сообщение
Или можно как-то укоротить запрос?
Да нет, только так... Но только...
1. не совсем понятно зачем искать что-то одновременно в поле Имя и в поле Адрес...
2. Отдельные условия в секции WHERE лучше брать в скобки:
SQL
1
WHERE (Name LIKE  '...') OR (Address LIKE  '...')
1
 Аватар для TrollHammer
1216 / 709 / 336
Регистрация: 22.02.2018
Сообщений: 2,095
Записей в блоге: 2
20.06.2019, 07:16
Цитата Сообщение от D1973 Посмотреть сообщение
Так что в данной ситуации - только OR
Немного не сообразил, подумал, что поиск значений во всех полях...
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.06.2019, 07:16
Помогаю со студенческими работами здесь

Как отобразить в DBGrid'e
Есть БД, в ней две таблицы. Подскажите, как в DBGrid'e отобразить данные из двух связанных таблиц? (Или нельзя так) Добавлено через 1...

Отобразить записи в dbgrid
Подключаю бд, с помощью ADOQuery отображаю данные в в dbgrid. Подскажите как после фильтрации отобразить все записи таблицы.

Отобразить столбец из DBGrid в строку
Здравствуйте. Имеется база данных с таблицами в Access. На форме есть компоненты ADOConnection, ADOQuery, ADODataSource. Все...

Отобразить в DBgrid Image по умолчанию
Здравствуйте. Есть база данных в которой есть папка с картинками. Т.е к каждой строке в DBGrid присвоено изображение от 1 - 17. ...

Отобразить таблицу Interbase в DbGrid
Здравствуйте! Вот только начал знакомство з базами данных. Необходимо зделать следующее: из файла *.gbd таблицу student в которую входят...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru