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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 11.05.2007, 14:24
Аватар для Сёна
Сёна Сёна вне форума
Прохожий
 
Регистрация: 02.05.2007
Адрес: Москва
Сообщения: 42
Версия Delphi: 7
Репутация: 10
По умолчанию SQL запрос из OracleDataSet

Подскажите please
получаю строку, хочу найти в таблице её id
код:
bsec:=form1.DBEdit3.Text;
sec.Close;
sec.SQL.Clear;
sec.SQL.Text:='select ROL_PASP_SEC_ID,ROL_PASP_SEC_NUM'+
' from rol_pasp_sec'+
' where ROL_PASP_SEC_NUM='+BSEC+'';
sec.Open;

idsec:=form1.sec.fieldbyname('ROL_PASP_SEC_ID').As Integer;

при sec.open выходит ошибка ora00904:Invalid column name
Ответить с цитированием
  #2  
Старый 11.05.2007, 15:35
AlexSku AlexSku вне форума
Специалист
 
Регистрация: 07.05.2007
Адрес: Москва
Сообщения: 884
Репутация: 21699
По умолчанию

Можешь вставить копию названия полей из базы данных? (Пишет - ошибка в названии поля)
Ответить с цитированием
  #3  
Старый 11.05.2007, 15:47
Holy Holy вне форума
Новичок
 
Регистрация: 31.07.2006
Сообщения: 55
Репутация: 10
По умолчанию

Попробуй так:
Код:
QuotedStr(BSEC)
Ответить с цитированием
  #4  
Старый 14.05.2007, 09:32
Аватар для Сёна
Сёна Сёна вне форума
Прохожий
 
Регистрация: 02.05.2007
Адрес: Москва
Сообщения: 42
Версия Delphi: 7
Репутация: 10
По умолчанию

QuotedStr не помогает
Названия полей

ROL_PASP_SEC_ID
ROL_PASP_SEC_NUM
ROL_PASP_SEC_ST
ROL_PASP_SEC_VID
ROL_PASP_SEC_UNRS
ROL_PASP_SEC_FNUM
ROL_PASP_SEC_BLOC
ROL_PASP_SEC_FSEC
ROL_PASP_SEC_ZAMNUM
ROL_PASP_SEC_TRZAM

Насчет ошибки в названии поля, то вроде всё верно, я уже несколько раз переделывала запрос, ему все равно не нравиться
Ответить с цитированием
  #5  
Старый 14.05.2007, 17:16
AlexSku AlexSku вне форума
Специалист
 
Регистрация: 07.05.2007
Адрес: Москва
Сообщения: 884
Репутация: 21699
По умолчанию

А зачем в конце два апострофа (+BSEC+'')? Может, их убрать: +BSEC
Ответить с цитированием
  #6  
Старый 15.05.2007, 10:18
Аватар для Сёна
Сёна Сёна вне форума
Прохожий
 
Регистрация: 02.05.2007
Адрес: Москва
Сообщения: 42
Версия Delphi: 7
Репутация: 10
По умолчанию

Если убрать апострофы, он не видит значения этой переменной и выводит такую же ошибку. Invalid column name.
Ответить с цитированием
  #7  
Старый 15.05.2007, 10:33
Holy Holy вне форума
Новичок
 
Регистрация: 31.07.2006
Сообщения: 55
Репутация: 10
По умолчанию

Чтобы получить такой текст запроса
Код:
select ROL_PASP_SEC_ID, ROL_PASP_SEC_NUM from rol_pasp_sec where ROL_PASP_SEC_NUM = '00000'
надо писать так:

Код:
SQL.Text:= 'select ROL_PASP_SEC_ID, ROL_PASP_SEC_NUM from rol_pasp_sec where ROL_PASP_SEC_NUM = ''' + '00000' + '''';
или так
Код:
SQL.Text:= 'select ROL_PASP_SEC_ID, ROL_PASP_SEC_NUM from rol_pasp_sec where ROL_PASP_SEC_NUM = ' + QuotedStr('00000');

В твоем случае вместо '00000' подставляй BSEC.
Если пользуешь первый способ, то строка, хранящаяся в переменной не должна содержать знак апострофа (').
Ответить с цитированием
  #8  
Старый 16.05.2007, 08:38
Аватар для Сёна
Сёна Сёна вне форума
Прохожий
 
Регистрация: 02.05.2007
Адрес: Москва
Сообщения: 42
Версия Delphi: 7
Репутация: 10
По умолчанию

Спасибо огромное!!!

Последний раз редактировалось Сёна, 16.05.2007 в 08:50.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter