Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 12.05.2014, 10:28
keldon1233 keldon1233 вне форума
Прохожий
 
Регистрация: 12.05.2014
Сообщения: 6
Версия Delphi: delphi 10
Репутация: 10
По умолчанию проблема с программой

Пишет ядро базы данных не может найти входную таблицу или запрос 'личная_карточка'.
Позможно ли осуществить запрос на form4 без применения adoquery.
Вложения
Тип файла: rar kurs.rar (519.5 Кбайт, 6 просмотров)
Ответить с цитированием
  #2  
Старый 12.05.2014, 10:38
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Если вы используете составные имена таблиц полей, то вам в запросе их надо обрамлять квадратными скобками:
select * from [личная карточка]
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #3  
Старый 12.05.2014, 12:21
keldon1233 keldon1233 вне форума
Прохожий
 
Регистрация: 12.05.2014
Сообщения: 6
Версия Delphi: delphi 10
Репутация: 10
По умолчанию

теперь пишет обнаружены символы за пределами инструкции SQL
Ответить с цитированием
  #4  
Старый 12.05.2014, 13:05
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Покажите эту самую инструкцию. У вас там случаем нет никакого лишнего текста после запроса?
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #5  
Старый 12.05.2014, 13:15
keldon1233 keldon1233 вне форума
Прохожий
 
Регистрация: 12.05.2014
Сообщения: 6
Версия Delphi: delphi 10
Репутация: 10
По умолчанию

SELECT Личная_карточка.Фамилия,
Личная_карточка.Имя,
Личная_карточка.Отчество,
Личная_карточка.[Дата рождения],
Личная_карточка.[номер паспорта],
Личная_карточка.Образование,
Личная_карточка.Профессия
FROM [Личная карточка] WHERE Личная_карточка.Фамилия=par1;
FROM [Личная карточка] WHERE личная_карточка.имя=par2;
FROM [Личная карточка] WHERE Личная_карточка.Отчество=par3;
FROM [Личная карточка] WHERE Личная_карточка.[Дата рождения]=par4;
FROM [Личная карточка] WHERE Личная_карточка.[номер паспорта]=par5;
FROM [Личная карточка] WHERE Личная_карточка.Образование=par6;
FROM [Личная карточка] WHERE Личная_карточка.профессия=par7;

Последний раз редактировалось keldon1233, 12.05.2014 в 13:21.
Ответить с цитированием
  #6  
Старый 12.05.2014, 13:15
keldon1233 keldon1233 вне форума
Прохожий
 
Регистрация: 12.05.2014
Сообщения: 6
Версия Delphi: delphi 10
Репутация: 10
По умолчанию

после равно должно быть двоеточие но тут появляются какие то смайлы

Последний раз редактировалось keldon1233, 12.05.2014 в 13:22.
Ответить с цитированием
  #7  
Старый 12.05.2014, 13:22
Аватар для poli-smen
poli-smen poli-smen вне форума
Профессионал
 
Регистрация: 06.08.2012
Адрес: Кривой Рог
Сообщения: 1,791
Версия Delphi: Delphi 7, XE2
Репутация: 4415
По умолчанию

Цитата:
Сообщение от keldon1233
FROM [Личная карточка] WHERE Личная_карточка.[номер паспорта]=par5;
FROM [Личная карточка] WHERE Личная_карточка.Образование=par6;
FROM [Личная карточка] WHERE Личная_карточка.профессия=par7;
Тогда понятно почему пишет что "обнаружены символы за пределами инструкции SQL".
Нужно делать примерно так:
Код:
 WHERE Личная_карточка.[номер паспорта]=par5 AND Личная_карточка.Образование=par6 AND Личная_карточка.профессия=par7
Ответить с цитированием
  #8  
Старый 12.05.2014, 13:53
keldon1233 keldon1233 вне форума
Прохожий
 
Регистрация: 12.05.2014
Сообщения: 6
Версия Delphi: delphi 10
Репутация: 10
По умолчанию

сделал теперь не хватает значений одного или нескольких параметров
Ответить с цитированием
  #9  
Старый 12.05.2014, 15:06
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Экий вы. Вы бы почитали про синтаксис SQL - сразу масса вопросов бы отпала.
Первое. После Where идет перечисление ограничений. С этим вы похоже разобрались.
Второе. В дельфи синтаксис параметров немного не такой:
Код:
SELECT Фамилия, Имя, Отчество, [Дата рождения], [номер паспорта], Образование, Профессия
FROM [Личная карточка] WHERE Фамилия=:par1 and имя=:par2 and Отчество=:par3 and [Дата рождения]=:par4 and [номер паспорта]=:par5
and Образование=:par6 and профессия=:par7;
И наконец, перед выполнением запроса, параметры надо заполнить:
Код:
AdoQuery1.Parameters.ParamValues['par1'] := 'Иванов';
...
AdoQuery1.Parameters.ParamValues['par7'] := 'столяр';
Кроме того, некоторые параметры пользователь может не заполнять и эту ситуацию вам тоже еще придется обработать. Подскажу, что для этого лучше использовать Like.
Дерзайте.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #10  
Старый 13.05.2014, 01:34
keldon1233 keldon1233 вне форума
Прохожий
 
Регистрация: 12.05.2014
Сообщения: 6
Версия Delphi: delphi 10
Репутация: 10
По умолчанию

код параметров у меня выглядит так
Код:
adoquery1.Parameters.ParamByName('par1').value:=edit1.Text;
adoquery1.Parameters.ParamByName('par2').value:=edit1.Text;
adoquery1.Parameters.ParamByName('par3').value:=edit1.Text;
adoquery1.Parameters.ParamByName('par4').value:=edit1.Text;
adoquery1.Parameters.ParamByName('par5').value:=edit1.Text;
adoquery1.Parameters.ParamByName('par6').value:=edit1.Text;
adoquery1.Parameters.ParamByName('par7').value:=edit1.Text;
adoquery1.Open;
dbgrid1.datasource.DataSet.Active:=true;

lmikle: Последнее китайское предупреждение.

предполагается что при вводе текста в edit1 программа выведет все строки базы данных в которых имеется данный текст

Последний раз редактировалось lmikle, 13.05.2014 в 04:53.
Ответить с цитированием
  #11  
Старый 13.05.2014, 01:45
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,723
Репутация: 52347
По умолчанию

Оформляйте правильно сообщение с кодом, иначе форум его будет неверно отображать, да еще и бан от модератора огребете за нарушение правил.
А что вы будете вводить в параметры, если вам надо будет найти человека только по Фамилии или только по Профессии?
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 16:53.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025