Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как заставить калькулятивное поле сохраняться в БД 
:(
    Опции темы
Delphist
  Дата 15.9.2009, 17:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Delphist Эксперт
****


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

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



Что-то я запарился, или старею  smile . Вообщем возникла не совмес стандартная ситуация, при разных режимах работы программы, одно и тоже поле в DataSet'e у меня может быть как fkData а в другом случае как fkCalculated. В обоих случаях за этим полем закреплено физическое поле БД. С fkData все понятно заносим в UpdateSQL sql-text типа:
Код

  update price_value
  set 
      price_id = :price_id,
      remainder = :remainder,
      income=:income,
      ...
  where (pv_id = :pv_id);


А вот как быть в случае с fkCalculated, как заставить автоматически изменяться значение в БД при пересчете его в программе? Делал так, но не помагло:
Код

procedure TMyForm.MyDataSetBeforeOpen(DataSet: TDataSet);
begin
  with DataSet do
  begin
     FieldByName('remainder').Value := FieldByName('income').Value - FieldByName('expense').Value;
     QUpdate.ExecQuery; //добавил эту строку, но толку мало.
   end;
end;


Это сообщение отредактировал(а) Delphist - 15.9.2009, 17:21


--------------------
ProcessInfo 1-ая моя программа (аналог spyxx.exe с гораздо большим функц-ом - внедрение dll в адр. простр. процесса, перехват API-функций, разбор приложения на окна мн.др).
Когда-то давным-давно использовал это...
PM MAIL ICQ   Вверх
dvamaster
Дата 22.9.2009, 13:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



проще сделать в отдельном запросе обновление

чтобы поле обновилось, датасет должен быть переведен в режим редактора
поле должно поменяться
датасет должен отправить данные
И в датасете должено присутствовать физическое поле соотвественно с другим именем

геморой

повторюсь
Цитата
проще сделать в отдельном запросе обновление

и отобразить реальное поле, залочив его от изменений


--------------------
Хорошую информацию трудно добыть. Сделать с ней что-нибудь - еще труднее. /L. Skywalker/

Что же я сделал не так? /Король Лир/

Я делаю это для твоего же блага! /Любой родитель и палач/

PKUNZIP.ZIP /неизвестный/
PM MAIL WWW ICQ   Вверх
Akella
Дата 22.9.2009, 16:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

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



Цитата
калькулятивное 

Может вычисляемое?
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.0812 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


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

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