Поиск:

Ответ в темуСоздание новой темы Создание опроса
> SQLDelete, ODAC 
V
    Опции темы
MacTep
Дата 10.4.2011, 12:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1292
Регистрация: 4.8.2003
Где: г. Самара

Репутация: нет
Всего: 4



Кто работал с Oracle Data Access Controls прошу помочь со следующим вопросом: как удалить данные программно из таблицы, использую OraQuery и свойство этого компонента SQLDelete. Не понимаю, почему у меня не работает следующий блок кода (вылезает ошибка о том, что параметр p_country_id не найден - почему он не определяется - не пойму):
Код

procedure TfrmCountryList.actDelExecute(Sender: TObject);
var tmp: Integer;
begin
  if (quCountries.Active) and (quCountries.RecordCount > 0) then
  begin
    tmp := quCountries.FieldByName('country_id').AsInteger;
    quCountries.ParamByName('p_country_id').AsInteger := tmp;
    quCountries.Delete;
  end;
end;
при этом у меня в SQLDelete на позиции Delete стоит такой текст
Код

update countries 
set is_del = 1 
where country_id = :p_country_id
Помогите, пожалуйста.


--------------------
(A)bort, (R)etry, (I)gnore = Haфиг, Heфиг, Пoфиг ... :)
PM MAIL   Вверх
MacTep
Дата 10.4.2011, 19:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1292
Регистрация: 4.8.2003
Где: г. Самара

Репутация: нет
Всего: 4



Актуально до сих пор smile


--------------------
(A)bort, (R)etry, (I)gnore = Haфиг, Heфиг, Пoфиг ... :)
PM MAIL   Вверх
cat512
Дата 10.4.2011, 19:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 438
Регистрация: 20.3.2007

Репутация: 1
Всего: 15



Select покажи. Дело в том что DAK-и, пересоздают параметры, которые можно инициализировать в обработчике (не помню точно) помойму beforeExecute. Если не пользовать такой обработчик,
то нужно что-бы наз. параметра соответствовало полю в select запросе. Тогда DAC, сам автоматом подставит параметр в запрос

Добавлено @ 19:33
По идее так должно сработать
Код

update countries 
set is_del = 1 
where country_id = :country_id

если в select-е есть поле country_id

Это сообщение отредактировал(а) cat512 - 10.4.2011, 19:34
PM MAIL   Вверх
Vas
Дата 11.4.2011, 07:16 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 830
Регистрация: 29.6.2005
Где: Stavropol region

Репутация: 23
Всего: 28



А так?
Код

update countries 
set is_del = 1 
where country_id = :old_country_id



--------------------
И опыт, сын ошибок трудных, И гений, парадоксов друг, И случай, бог изобретатель. ... (А.С. Пушкин)
PM MAIL   Вверх
MacTep
Дата 11.4.2011, 08:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1292
Регистрация: 4.8.2003
Где: г. Самара

Репутация: нет
Всего: 4



Так
Код

update countries 
set is_del = 1 
where country_id = :old_country_id
 не работает.
Select был обычный что-то типа select t.* from countries t, причем поле айдишника называлось именно country_id. Вариант, предложенный cat512, попробую вечером.


--------------------
(A)bort, (R)etry, (I)gnore = Haфиг, Heфиг, Пoфиг ... :)
PM MAIL   Вверх
Vas
Дата 11.4.2011, 08:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 830
Регистрация: 29.6.2005
Где: Stavropol region

Репутация: 23
Всего: 28



Не дочитал я, в SQLUpdate будет работать с префиксом old_
А в SQLDelete просто по имени надо использовать, как cat512 написал.


--------------------
И опыт, сын ошибок трудных, И гений, парадоксов друг, И случай, бог изобретатель. ... (А.С. Пушкин)
PM MAIL   Вверх
toreh
Дата 11.4.2011, 22:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 14
Регистрация: 11.4.2011

Репутация: нет
Всего: нет



помогите у меня почти такая же проблема только база в прадоксе с делана имеется sql запрос выводит данные из базы ну я их не могу редактировать и не могу к ним подклюсить dbedit 
PM MAIL   Вверх
MacTep
Дата 11.4.2011, 22:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1292
Регистрация: 4.8.2003
Где: г. Самара

Репутация: нет
Всего: 4



Цитата(toreh @  11.4.2011,  22:36 Найти цитируемый пост)
помогите у меня почти такая же проблема только база в прадоксе с делана имеется sql запрос выводит данные из базы ну я их не могу редактировать и не могу к ним подклюсить dbedit  

Одна проблема, один топик. Стартуй свой. Этот считаю закрытым. Спасибо! ;)


--------------------
(A)bort, (R)etry, (I)gnore = Haфиг, Heфиг, Пoфиг ... :)
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: Базы данных и репортинг"
Vit
Петрович

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


Обязательно указание:

1. Базы данных (Paradox, Oracle и т.п.)

2. Способа доступа (ADO, BDE и т.д.)


  • Литературу по Дельфи обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи
  • Вопросы по SQL и вопросы по базам данных не связанные с Дельфи задавать здесь

FAQ раздела лежит здесь!


Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Vit, Петрович.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: Базы данных и репортинг | Следующая тема »


 




[ Время генерации скрипта: 0.0685 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.