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

Ошибка синтаксиса (пропущен оператор) в выражении запроса в Дельфи

21.01.2018, 17:58. Показов 3961. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго дня, уважаемым программистам!

Мой вредный шеф захотел не один универсальный поиск. А два независимых. Один по точному соответствию (регистрационный номер), второй по совпадению символов (улица). Работаю с Дельфи и Акцессом.

Когда был второй вариант поиска, все было хорошо. Но когда я добавил еще и первый, то при вводе в TEdit и нажатии кнопки "Поиск" выдает ошибку: "Ошибка синтаксиса (пропущен оператор) в выражении запроса".

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

Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
procedure TForm2.BitBtn4Click(Sender: TObject); // Кнопка поиск, после нажатия на которую и выскакивает ошибка
var NomReg: Array of string;
    i,h,Counts: integer;
    Find, Result:string;
 
begin
    SetLength(NomReg, 10000);
    Counts:=1;
    ADODataSet1.Active:=true;
    ADODataSet1.First;
    for i := 0 to ADODataSet1.RecordCount -1 do
        begin
           NomReg[i]:=ADODataSet1.FieldValues['Nom_reg'];
           ADODataSet1.Next;
           Inc(Counts);
         end;
 
     Find:=Trim(Edit5.Text);
 
     for h := 0 to Counts do
        begin
           if Find = NomReg[h] then
              begin
                with Form2.ADOQuery_Baza do
                  begin
                    Close;
                    SQL.Clear;
                    SQL.Add('select * from Inf_Lift_full where Nom_reg like=' + Find ); // По этой строке и выбивает ошибку!!!
                    Open;
                  end;
 
                 Label8.Caption:='Есть попадание!';
              end
           else  Label8.Caption:='Лифт с таким рег.номером не обслуживается!';
        end;
 
end;
 
procedure TForm2.Edit1Change(Sender: TObject);  // старый поиск, который работает, по нему вопросов не было
  var help1, help2: string;                                     // оставил его на всякий... может будет понятнее
begin
  help1:='%'+ Form2.Edit1.Text+ '%';
  help2:= QuotedStr(help1);
  with Form2.ADOQuery_Baza do
    begin
      Close;
      SQL.Clear;
      SQL.Add('select * from Inf_Lift_full where Nom_reg like' +help2+ ' or Adres_full like' +help2 );
      Open;
    end;
end;
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
21.01.2018, 17:58
Ответы с готовыми решениями:

Ошибка синтаксиса: пропущен оператор в выражении запроса
нужно удалить строку из связанной таблицы. но при компиляции выдает ошибку "Ошибка синтаксиса (пропущен оператор) в выражении запроса...

Ошибка синтаксиса пропущен оператор в выражении запроса
У меня есть база данных в акцессе и я работаю с ней через делфи у меня возникла проблема с запросом procedure...

Ошибка синтаксиса (пропущен оператор) в выражении запроса
Ошибка синтаксиса (пропущен оператор) в выражении запроса 'R.Kod_Stepeni=RD.Kod_Stepeni AND R.Tab_nomer=' ..... помагите в чём может быть...

10
 Аватар для Sibarit
0 / 0 / 0
Регистрация: 08.01.2018
Сообщений: 7
21.01.2018, 19:53  [ТС]
Спасибо, обязательно гляну. Т.к. активно изучаю этот вопрос по мере возможностей и загруженности. А если ближе к теме?
0
Айлурофил
 Аватар для Massaraksh7
511 / 445 / 111
Регистрация: 27.05.2017
Сообщений: 2,680
Записей в блоге: 5
21.01.2018, 20:03
Ужас какой-то. Зачем тут массив?
1
 Аватар для Sibarit
0 / 0 / 0
Регистрация: 08.01.2018
Сообщений: 7
21.01.2018, 20:47  [ТС]
ну, у меня в базе более 7 тысяч записей и поэтому я предпочел вначале все их посчитать, чтобы знать, какое количество раз сравнивать введенное число с искомым значением
0
 Аватар для Пытливый
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
21.01.2018, 20:52
Ну дык и пусть пользователь сам и решает, как ему удобнее искать с % или без. Уберите просто %:
Delphi
1
help1:=Form2.Edit1.Text;
1
 Аватар для Sibarit
0 / 0 / 0
Регистрация: 08.01.2018
Сообщений: 7
21.01.2018, 21:26  [ТС]
Поразмышляв по глубже над удивлением господина Massaraksh7, я упростил код почти в четверо и... все заработало. Прошу прощения, за свою неграмотность, но вы и вправду мне помогли. Для таких же неумех выкладываю итоговый код:

Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
procedure TForm2.BitBtn4Click(Sender: TObject);
begin
  with Form2.ADOQuery_Baza do                                           // переделанный новый
     begin
     Close;
     SQL.Clear;
     SQL.Add('select * from Inf_Lift_full where Nom_reg like ' + Edit5.Text + ';');   // исправленная проблемная строка
     Open;
     end;
end;
 
procedure TForm2.Edit1Change(Sender: TObject);   // старый, работающий поиск
  var help1, help2: string;
begin
  help1:='%'+ Form2.Edit1.Text+ '%';
  help2:= QuotedStr(help1);
  with Form2.ADOQuery_Baza do
    begin
      Close;
      SQL.Clear;
      SQL.Add('select * from Inf_Lift_full where Nom_reg like' +help2+ ' or Adres_full like' +help2 );
      Open;
    end;
end;
Добавлено через 10 минут
Цитата Сообщение от Пытливый Посмотреть сообщение
Ну дык и пусть пользователь сам и решает, как ему удобнее искать с % или без. Уберите просто %:
DelphiВыделить код1
help1:=Form2.Edit1.Text;
Пытливый, в том-то и дело, что несмотря на многочисленные споры шеф уперся и требует СРАЗУ две поисковые строки на одной панели
0
Эксперт Pascal/Delphi
 Аватар для xxbesoxx
1135 / 616 / 129
Регистрация: 13.02.2009
Сообщений: 3,600
21.01.2018, 23:21
1) Там Trim надо ! А то случайный пробел и результат будет не ТО
Delphi
1
SQL.Add('select * from Inf_Lift_full where Nom_reg like ' + Trim(Edit5.Text) + ';');
2) Что такой Edit5 ? надо же имя осмысленный, на пример edtSearch
Цитата Сообщение от Sibarit Посмотреть сообщение
шеф уперся и требует СРАЗУ две поисковые строки на одной панели
Не понял ?! Вы хотите из одного Edit- поиск на разных полей и переключит через RadioButton или что ?

Добавлено через 6 минут
Это что ?
Delphi
1
 help2:= QuotedStr(help1);
1
 Аватар для Sibarit
0 / 0 / 0
Регистрация: 08.01.2018
Сообщений: 7
22.01.2018, 00:26  [ТС]
Цитата Сообщение от xxbesoxx Посмотреть сообщение
1) Там Trim надо ! А то случайный пробел и результат будет не ТО
DelphiВыделить код1
SQL.Add('select * from Inf_Lift_full where Nom_reg like ' + Trim(Edit5.Text) + ';');
Спасибо большое, уже поправил

xxbesoxx, Edit5 - это поисковая строка по рег.номеру (с которой были траблы). А Edit1 описанный в коде, это вторая поисковая строка в которой раньше искало по всем колонкам, но с появлением Edit5 ищет только по улице. Т.е. как я и говорил раньше:
Цитата Сообщение от xxbesoxx Посмотреть сообщение
Сообщение от Sibarit
шеф уперся и требует СРАЗУ две поисковые строки на одной панели
Но проблема в том, что на улицах бывает много домов и он хочет еще одну поисковую строку... Сейчас ломаю голову над Edit7, строку, которая должна из выбранной по Edit5 улице, найти № дома...
Миниатюры
Ошибка синтаксиса (пропущен оператор) в выражении запроса в Дельфи  
0
 Аватар для Sibarit
0 / 0 / 0
Регистрация: 08.01.2018
Сообщений: 7
22.01.2018, 00:29  [ТС]
Цитата Сообщение от xxbesoxx Посмотреть сообщение
Это что ?
DelphiВыделить код1
help2:= QuotedStr(help1);
Это подсмотрел на Ютубе. До конца не понимаю, но думал, что так надо. Я ошибаюсь?
0
Эксперт Pascal/Delphi
 Аватар для xxbesoxx
1135 / 616 / 129
Регистрация: 13.02.2009
Сообщений: 3,600
22.01.2018, 02:46
Лучший ответ Сообщение было отмечено Sibarit как решение

Решение

Цитата Сообщение от Sibarit Посмотреть сообщение
что на улицах бывает много домов и он хочет еще одну поисковую строку... Сейчас ломаю голову над Edit7, строку, которая должна из выбранной по Edit5 улице, найти № дома...
Посмотрите пожалуйста Сформировать запрос из нескольких Edit
1
 Аватар для Sibarit
0 / 0 / 0
Регистрация: 08.01.2018
Сообщений: 7
22.01.2018, 03:18  [ТС]
Цитата Сообщение от xxbesoxx Посмотреть сообщение
Сообщение от Sibarit
что на улицах бывает много домов и он хочет еще одну поисковую строку... Сейчас ломаю голову над Edit7, строку, которая должна из выбранной по Edit5 улице, найти № дома...
Посмотрите пожалуйста Сформировать запрос из нескольких Edit
xxbesoxx, спасибо Вам ОГРОМНОЕ, Вы мне ОЧЕНЬ помогли! Наконец-то могу пойти спать. Поиск сделал, остальное потом...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
22.01.2018, 03:18
Помогаю со студенческими работами здесь

Ошибка синтаксиса пропущен оператор в выражении запроса
var b,a :string ; begin A:='%'+Form1.Edit1.Text+'%'; b:=QuotedStr(a); with form1.ADOQuery1 do begin close; SQL.Clear ; ...

Ошибка синтаксиса (пропущен оператор) в выражении запроса ДБ
Вообщем делаю поиск,вот пример по табличке ДБ с MA procedure TForm1.sEdit1Change(Sender: TObject); var help1, help2:string; begin ...

Запрос на поиск выдает ошибку ошибка синтаксиса (пропущен оператор в выражении запроса), как исправить?
DM.MaterialQuery.SQL.Add('SELECT Materiali.ID_materiala, Materiali.Tip_materiala, Materiali.Name_materiala, Materiali.Edinica,...

Ошибка: "Ошибка синтаксиса (пропущен оператор в выражении запроса ID Stud Like%1% "
Не могу осуществить поиск по бд. Как только ввожу что хочу найти, выскакивает ошибка "Ошибка синтаксиса (пропущен оператор в выражении...

Запрос и ошибка синтаксиса (пропущен оператор)
Вот такая штука, вылетает "ошибка синтаксиса (пропущен оператор)" в том месте, где "Дата=" В Access тот же запрос вроде как...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Сем 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. На борту пять. . .
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru