Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/18: Рейтинг темы: голосов - 18, средняя оценка - 4.67
 Аватар для Мусаси
9 / 9 / 2
Регистрация: 07.05.2013
Сообщений: 227

SQL запрос в Delphi (поиск по Id - счетчик)

09.12.2013, 00:35. Показов 3676. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем добрый вечер. Возникла такая проблема, как организовать SQL запрос (поиск по ID). Id является счетчиком. Я организовал запрос по таблице Заказы, но он не показывает мне ожидаемый результат. Уже полдня над этим голову ломаю.
Я предоставляю код. В чем ошибка? За ранее спасибо

Delphi
1
2
3
4
5
if (DataModule2.QueryZAKAZI.Active) then
DataModule2.QueryZAKAZI.Close;
DataModule2.QueryZAKAZI.SQL.Clear;
DataModule2.QueryZAKAZI.SQL.Add('select *from Заказы where "Id zakaz" = "' + Edit1.Text+'"');
DataModule2.QueryZAKAZI.Open;
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.12.2013, 00:35
Ответы с готовыми решениями:

Delphi SQL запрос поиск в таблице по дате
Все добрый вечер! Нужна помощь. Создал SQL запрос, который позволяет при вводе в поле Edit и нажатии на кнопку находить записи в таблице....

SQL-запрос в Delphi и в Access один и тот же, но в Delphi не работает
ри обращение к базе в Access я использую код: with ADOQueryMain do begin Active:=false; SQL.Clear; SQL.Add('SELECT Code,...

SQL и ComboBox в Delphi. Нужно чтобы при выборе специальности в комбобоксе это значение вносилось в SQL запрос
procedure TForm3.Button2Click(Sender: TObject); begin try ADOQuery1.SQL.Clear; ADOQuery1.SQL.Add('SELECT Абитуриент.фамилия,...

14
Native x86
Эксперт Hardware
 Аватар для quwy
6858 / 3791 / 1025
Регистрация: 13.02.2013
Сообщений: 11,861
09.12.2013, 00:47
Что именно не работает? Ошибка возникает? База данных какая?

Попробую поиграть в телепата и предположу, что возникает исключение неправильного синтаксиса SQL-запроса, и база -- MS ACCESS.

1. Для полей с пробелами корректный синтаксис такой:
SQL
1
SELECT * FROM Заказы WHERE [Id zakaz] = ...
2. Никогда не подставляйте в запрос значение, введенное пользователем в текстовое поле.

3. Программа ваша должна иметь примерно такой вид:
Delphi
1
2
3
4
if DataModule2.QueryZAKAZI.Active then DataModule2.QueryZAKAZI.Close;
DataModule2.QueryZAKAZI.SQL.Text:= 'select * from Заказы where [Id zakaz] = :Order';
DataModule2.QueryZAKAZI.ParamByName('Order').AsInteger:= StrToInt(Edit1.Text);
DataModule2.QueryZAKAZI.Open;
При этом нужно либо запретить пользователю вводить в Edit1 что-либо кроме цифр, либо использовать не TEdit, а что-то предназначенное для ввода целых чисел, например TSpinEdit.
0
 Аватар для Мусаси
9 / 9 / 2
Регистрация: 07.05.2013
Сообщений: 227
09.12.2013, 01:03  [ТС]
Вот что он пишет при твоем коде: Project Project1.exe raised exception class EDBEngineError with message Ínvalid use of keyword.
Token: [Id
Line Number: 1'.Process stopped. Use Step or Run to continue.

При моем коде показывает все пустые поля таблицы. Т.е. я не вижу ожидаемого результата, который ввожу.
0
 Аватар для Algoritmer
159 / 98 / 25
Регистрация: 07.03.2013
Сообщений: 513
Записей в блоге: 1
09.12.2013, 01:14
Мусаси, попробуй так
Delphi
1
DataModule2.QueryZAKAZI.SQL.Add('select *from Заказы where "Id zakaz" = ' + Edit1.Text);
А вообще ты можешь свой id zakaz как-то по нормальному назвать (без пробелов и все букву большие вот так например: ID_ZAKAZ) и сразу станет легче. Не нужно будет брать его в двойные кавычки...
0
Native x86
Эксперт Hardware
 Аватар для quwy
6858 / 3791 / 1025
Регистрация: 13.02.2013
Сообщений: 11,861
09.12.2013, 01:20
Цитата Сообщение от Мусаси Посмотреть сообщение
Вот что он пишет при твоем коде: Project Project1.exe raised exception class EDBEngineError with message Ínvalid use of keyword.
Token: [Id
Line Number: 1'.Process stopped. Use Step or Run to continue.
Значит фиговый из меня телепат. А Algoritmer дело говорит, завязывали бы вы с пробелами и кириллицей в служебных идентификаторах. Пользователь их все равно не видит, а программам только лишние неоднозначности.
0
 Аватар для Мусаси
9 / 9 / 2
Регистрация: 07.05.2013
Сообщений: 227
09.12.2013, 01:38  [ТС]
Побывал использовать твой компонент, но выдает результат такой же - пустая таблица

Добавлено через 8 минут
Кстати, мужики, при создании запроса в Database Desktop он выделяет это поле в двойные кавычки. Так, что не в кавычках дело. Вы случаем не знаете как запросы созданные в Database Desktop внедрить в делфи?

Добавлено через 7 минут
Какие есть еще варианты?
0
Native x86
Эксперт Hardware
 Аватар для quwy
6858 / 3791 / 1025
Регистрация: 13.02.2013
Сообщений: 11,861
09.12.2013, 02:00
Мусаси, BDE -- это как DOS. Когда-то он был повсеместно распространен, но его время прошло и теперь ему пора на покой. Используйте актуальные компоненты доступа к БД. И не обзывайте поля кириллическими именами с пробелами, ничего кроме проблем это вам не принесет.
1
 Аватар для Мусаси
9 / 9 / 2
Регистрация: 07.05.2013
Сообщений: 227
09.12.2013, 02:05  [ТС]
И как тогда решить мою проблему?
0
Native x86
Эксперт Hardware
 Аватар для quwy
6858 / 3791 / 1025
Регистрация: 13.02.2013
Сообщений: 11,861
09.12.2013, 02:30
1. Для доступа к БД использовать компоненты из вкладки ADO (dbGO в новых версиях Delphi)
2. Переделать базу данных так, чтобы имена таблиц и полей не содержали ни кириллических символов, ни пробелов.
0
 Аватар для Пытливый
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
09.12.2013, 02:52
Вам уже дали решение - оформляйте названия составных полей в квадратные скобки.
0
 Аватар для Мусаси
9 / 9 / 2
Регистрация: 07.05.2013
Сообщений: 227
09.12.2013, 09:37  [ТС]
???
Вложения
Тип файла: rar БАЗА.rar (362.3 Кб, 18 просмотров)
0
 Аватар для Мусаси
9 / 9 / 2
Регистрация: 07.05.2013
Сообщений: 227
09.12.2013, 09:52  [ТС]
Просмотрите тогда мою БД.
0
 Аватар для Пытливый
3763 / 2267 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
09.12.2013, 13:08
Посмотрел. Очень смутно помню особенности работы с парадоксом. Могу сказать только вот что - поле [Id zakaz] по которому вы делаете выборку - счетчик, т.е. числовое, а вы к нему как к строке пытаетесь обратится. Заключать в квадратные скобки поля похоже тоже не вариант, хотя это как-то странно - ибо стандарт. Ну да ладно, помогает заключение в "". Но вот почему тогда при выполнении запроса:
SQL
1
SELECT * FROM Заказы WHERE "Id zakaz"=1
мы получаем ошибку Выражение неопределенного типа - не пойму. Может кто с парадоксом получше знаком подскажет в чем засада.
0
 Аватар для Algoritmer
159 / 98 / 25
Регистрация: 07.03.2013
Сообщений: 513
Записей в блоге: 1
09.12.2013, 13:20
Цитата Сообщение от Мусаси Посмотреть сообщение
Просмотрите тогда мою БД.
По базе вряд ли что-то подскажу, моя стихия Firebird, с Paradox-ом не работал. Тебе уже сказали всё что можно было сказать. Единственное, добавлю, если при создании запроса конструктор выделяет твое поле в двойные кавычки, значит двойные кавычки там и должны быть; никаих квадратных скобок!!!
Твоя ошибка была в том, что ты брал в двойные кавычки значение из Edit-a, а там должны быть одинарные. Поэтому, раз уж ты намутил с именами полей, оставь всё как есть (но на будущее никогда так не делай), а запрос твой сделай так:
Delphi
1
2
3
4
5
6
if (DataModule2.QueryZAKAZI.Active) then
DataModule2.QueryZAKAZI.Close;
DataModule2.QueryZAKAZI.SQL.Clear;
DataModule2.QueryZAKAZI.SQL.Add('select * from Заказы where "Id zakaz" =:idzak');
DataModule2.QueryZAKAZI.ParamByName('idzak').asstring:=Edit1.Text;
DataModule2.QueryZAKAZI.Open;
Добавлено через 2 минуты
Мусаси, а ещё у тебя
Delphi
1
*from
без пробела написано!!!
0
 Аватар для Мусаси
9 / 9 / 2
Регистрация: 07.05.2013
Сообщений: 227
09.12.2013, 13:23  [ТС]
Спасибо, мужики, я уже разобрался. Переделал в БД поля без пробелов и все заработало!!!!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.12.2013, 13:23
Помогаю со студенческими работами здесь

Delphi и SQL Выборка из связанных таблиц, по ключевым полям с разными типами (счётчик-текстовый)
Всем доброго времени суток. Разрабатываю программу по учёту сотрудников. Проделана очень большая работа, много функций. В БД около 20...

Delphi SQL-запрос
Есть таблица - ФИО участника и результат его забега на 3 км. Нужно вывести победителя на каждой дистанции в Edit. procedure...

Запрос из Delphi к MS SQL
Имеется SQL Server на моем ПК, Имя сервера iluxa, проверка подлинности осуществляется с через WIndows, БД master. Почему-то запрос...

Delphi sql запрос
Здравствуйте , мне нужна помощь в реализации двух sql запросов . Нужно чтобы они выполнялись по нажатию на 2 разные кнопку . Сам я уже...

Sql запрос в Delphi 7
Здравствуйте! Есть медицинская база данных в ней таблицы: Пациенты (Фио, Пол, ДатаРождения, Адрес), Диагнозы(№пациента, Название болезни),...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
Реалии
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 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru