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

ADOQuery не выполняет запрос SQL

20.08.2012, 10:00. Показов 8244. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите, пожалуйста, по такому вопросу,

Имеем,
Delphi XE,
MS SQL 2012

В DataModule1 ADOConnection + ADOQuery + DataSource
На форме DBGrid и TEdit
В ADOQuery в свойстве SQL написано:

SQL
1
2
SELECT * FROM Users
ORDER BY LastName
Данный селект отрабатывает нормально и DBGrid показывает все данные и сортирует по фамилии.
На обработчике OnChange компонента TEdit написан следующий код:

Delphi
1
2
3
4
5
6
7
8
9
procedure TForm2.FindEditChange(Sender: TObject);
begin
  DataModule1.ADOQuery1.Active:=false;
  DataModule1.ADOQuery1.SQL.Clear;
  DataModule1.ADOQuery1.SQL.Add('SELECT *') ;
  DataModule1.ADOQuery1.SQL.Add('FROM Users');
  DataModule1.ADOQuery1.SQL.Add('WHERE LastName LIKE '''+Form2.FindEdit.Text+'''');
  DataModule1.ADOQuery1.Active:=true;
end;
При попытке что-либо написать в компоненте TEdit DBGrid просто очищается и больше ничего не происходит.

Задача состоит в том что бы при написании Фамилии в компоненте TEdit DBGrid сразу отображал то что подходит под написанное: Например при написании буквы "п" отображались все фамилии содержащие эту букву, при написании "пр" отображались фамилии содержащие это буквосочетание и т.д.
Прошу помощи так как уже 2-й день бьюсь с поиском
Заранее благодарен.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.08.2012, 10:00
Ответы с готовыми решениями:

SQL запрос в ADOQuery
Извиняюсь, если пишу не в ту тему, так как по сути мне нужна помощь по SQL, просто используется он в ADOQuery. Вообщем есть код (фрагмент...

SQL Запрос в ADOQuery
Проблема заключается в том что простой запрос типа Select * from SKLAD работает. А запрос чуть по крупнее который рабочий...

Adoquery SQL-запрос
Есть таблица с группами(Group), и со студентами(Student). И есть dblookupcombobox1, привязанный к таблице с группами. Не получается...

7
 Аватар для Ice_and_Fire
512 / 298 / 37
Регистрация: 22.06.2011
Сообщений: 929
20.08.2012, 10:54
Называется это инкрементный поиск.
Ошибка в операторе like, у Вас отсутствует маска % (искомые текст%)

Не по теме:

Имеем,
Delphi XE,
MS SQL 2012
и откуда у людей средствА

0
Эксперт Pascal/Delphi
 Аватар для xxbesoxx
1135 / 616 / 129
Регистрация: 13.02.2009
Сообщений: 3,600
20.08.2012, 11:16
Цитата Сообщение от Dandy777 Посмотреть сообщение
Подскажите, пожалуйста, по такому вопросу,

Имеем,
Delphi XE,
MS SQL 2012

В DataModule1 ADOConnection + ADOQuery + DataSource
На форме DBGrid и TEdit
В ADOQuery в свойстве SQL написано:

SQL
1
2
SELECT * FROM Users
ORDER BY LastName
Данный селект отрабатывает нормально и DBGrid показывает все данные и сортирует по фамилии.
На обработчике OnChange компонента TEdit написан следующий код:

Delphi
1
2
3
4
5
6
7
8
9
procedure TForm2.FindEditChange(Sender: TObject);
begin
  DataModule1.ADOQuery1.Active:=false;
  DataModule1.ADOQuery1.SQL.Clear;
  DataModule1.ADOQuery1.SQL.Add('SELECT *') ;
  DataModule1.ADOQuery1.SQL.Add('FROM Users');
  DataModule1.ADOQuery1.SQL.Add('WHERE LastName LIKE '''+Form2.FindEdit.Text+'''');
  DataModule1.ADOQuery1.Active:=true;
end;
При попытке что-либо написать в компоненте TEdit DBGrid просто очищается и больше ничего не происходит.

Задача состоит в том что бы при написании Фамилии в компоненте TEdit DBGrid сразу отображал то что подходит под написанное: Например при написании буквы "п" отображались все фамилии содержащие эту букву, при написании "пр" отображались фамилии содержащие это буквосочетание и т.д.
Прошу помощи так как уже 2-й день бьюсь с поиском
Заранее благодарен.
Пожалуйста смотрите

Delphi
1
2
3
4
5
6
7
8
9
procedure TForm1.Edit1Change(Sender: TObject);
begin
ADOQuery1.Active:=false;
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT*');
ADOQuery1.SQL.Add('FROM Komadirovka');
ADOQuery1.SQL.Add('WHERE Фамилия LIKE '''+Edit1.Text + '%' + '''');
ADOQuery1.Active:= true;
end;
Вложения
Тип файла: rar Search.rar (330.8 Кб, 161 просмотров)
1
0 / 0 / 0
Регистрация: 16.08.2012
Сообщений: 6
20.08.2012, 11:27  [ТС]
Цитата Сообщение от Ice_and_Fire Посмотреть сообщение
Называется это инкрементный поиск.
Ошибка в операторе like, у Вас отсутствует маска % (искомые текст%)

Не по теме:

и откуда у людей средствА

Вы не могли бы по синтаксису подсказать куда и как эту маску вставить?
0
Эксперт Pascal/Delphi
 Аватар для xxbesoxx
1135 / 616 / 129
Регистрация: 13.02.2009
Сообщений: 3,600
20.08.2012, 11:40
Цитата Сообщение от Dandy777 Посмотреть сообщение
Вы не могли бы по синтаксису подсказать куда и как эту маску вставить?
Delphi
1
2
3
4
5
6
7
8
9
procedure TForm2.FindEditChange(Sender: TObject);
begin
  DataModule1.ADOQuery1.Active:=false;
  DataModule1.ADOQuery1.SQL.Clear;
  DataModule1.ADOQuery1.SQL.Add('SELECT *') ;
  DataModule1.ADOQuery1.SQL.Add('FROM Users');
  DataModule1.ADOQuery1.SQL.Add('WHERE LastName LIKE '''+Form2.FindEdit.Text+ '%' +'''');
  DataModule1.ADOQuery1.Active:=true;
end;
Что вы не поняли ? Копируете пожалуйста
2
0 / 0 / 0
Регистрация: 16.08.2012
Сообщений: 6
20.08.2012, 11:41  [ТС]
Цитата Сообщение от xxbesoxx Посмотреть сообщение
Пожалуйста смотрите

Delphi
1
2
3
4
5
6
7
8
9
procedure TForm1.Edit1Change(Sender: TObject);
begin
ADOQuery1.Active:=false;
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT*');
ADOQuery1.SQL.Add('FROM Komadirovka');
ADOQuery1.SQL.Add('WHERE Фамилия LIKE '''+Edit1.Text + '%' + '''');
ADOQuery1.Active:= true;
end;
Вы ГЕНИЙ!!!!!
Спасибо огромное. 2 дня бился над этим поиском.
мне нехватало всего лишь вот этого
Delphi
1
'''+Edit1.Text + '%' + ''''
а именно вот этой части '%' +
Эм, пользуясь моментом вопросик по синтаксису - какую роль выполняет вот этот знак +

Вопрос решен.
0
Эксперт Pascal/Delphi
 Аватар для xxbesoxx
1135 / 616 / 129
Регистрация: 13.02.2009
Сообщений: 3,600
20.08.2012, 11:42
Лучший ответ Сообщение было отмечено как решение

Решение

Цитата Сообщение от Dandy777 Посмотреть сообщение
Вы ГЕНИЙ!!!!!
Спасибо огромное. 2 дня бился над этим поиском.
мне нехватало всего лишь вот этого
Delphi
1
'''+Edit1.Text + '%' + ''''
а именно вот этой части '%' +
Эм, пользуясь моментом вопросик по синтаксису - какую роль выполняет вот этот знак +

Вопрос решен.
Для спасибо ест КНОПКА
4
 Аватар для Ice_and_Fire
512 / 298 / 37
Регистрация: 22.06.2011
Сообщений: 929
20.08.2012, 11:42
Delphi
1
'WHERE LastName LIKE '''+Form2.FindEdit.Text+'%'''
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
20.08.2012, 11:42
Помогаю со студенческими работами здесь

ADOQuery + SQL запрос с условием ???
Мне необходимо выбрать из таблицы Person (ID, Name, Secondname, Birthday...) только 3 поля, причем 2 из них объединить: SELECT P.ID,...

Delphi + ADOQuery+ Запрос SQL
Добрый день уважаемые програмисты! Помогите разобраться с запросом. Есть две таблицы Stb с поляли StbKey, Num, Gr, GrP, Name и Bdg с...

SQL запрос для AdoQuery
Каким будет запрос SQL если имеется таблица id_uspev id_uch id_dist ocenka semestr Необходимо при выборе через ComboBox1...

ADOQuery - SQL запрос для вывода дубликатов
Привет всем. Подскажите как сформулировать SQL запрос чтобы вывелись все записи с повторяющимися значениями в одном столбце? Конкретнее:...

ADOQuery: ввод переменой с клавиатуры в sql запрос
Доброго времени суток. По задумке пользователь программы должен ввести в Edit процент на который будут изменены все значения в столбце...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru