Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2005.03.13;
Скачать: [xml.tar.bz2];

Вниз

Сохранение текущего значения при работе с кэшем   Найти похожие ветки 

 
Бульбаш   (2005-01-28 09:56) [0]

При использовании кэширования не сохраняются данные (при applyupdates)если не покинуть текущую строку. Я пока выхожу из ситуации через Next перед сохранением. Может существует более изящное решение?


 
Sergey13 ©   (2005-01-28 10:01) [1]

Так может Post вместо Next?


 
Бульбаш   (2005-01-28 10:07) [2]

А Post в этом случае применяется к кэшированным данным?


 
Sergey13 ©   (2005-01-28 10:12) [3]

А Next применяется? 8-)
Просто Next неявно вызывает Post который тебе и нужен повидимому.


 
Бульбаш   (2005-01-28 10:36) [4]

Действительно :)


 
Бульбаш   (2005-02-11 16:11) [5]

Пришлось вернуться к этой проблеме. Чуть подробнее: Пользователь редактирует запись в гриде: например ставит птичку в chekbox или редактирует текстовое поле и сразу давит на кнопку сохранить (по ней же идет ApplyUpdate и т.д.),не переходя на другое поле и не нажимая enter. После переоткрытия набора данных обновления поля не происходит. Пробую принудительный пост:
if DM.Org.Modified then DM.Org.Post; тот же результат... Если же использовать навигатор - нажатием его Post-а сохраняется.(но навигатор здесь неприемлем). Подскажите как решить проблемку плиз


 
Val ©   (2005-02-11 16:24) [6]

пост OnExit сетки, если открыт датасет.


 
Val ©   (2005-02-11 16:28) [7]

Кcтати, for info, при использовании кеша, м.б. недостаточно одного Modified, стоит анализировать и UpdatesPending:
if DataSet.Modified or TBDEDataSet(DataSet).UpdatesPending...


 
Бульбаш   (2005-02-11 16:43) [8]

И так не работает :( а updatesPending я анализирую в обработчике нажатия кнопки...


 
Val ©   (2005-02-11 16:45) [9]

не работает что? нет Post? нет OnExit?


 
stud ©   (2005-02-11 16:53) [10]

так может state датасета анализировать? если в редактировании или вставке постить данные.


 
Бульбаш   (2005-02-11 17:05) [11]

Т.е.получается что если не вышел из поля или не нажал Enter изменения не фиксируются. Если принудительно просто дать Post - вылетает по ORA-01086 (была сделана попытка отката к savepoint, которая не установлена). Но если нажать сохранить в навигаторе - то все фиксируется - знать бы как там все это реализовано?


 
Desdechado ©   (2005-02-11 17:42) [12]

if( dataset.state in [dsEdit, dsInsert] ) then
dataset.post;

кстати, как это у тебя на post сразу оракл ругается? ты ж вроде используешь кэширование?


 
Бульбаш   (2005-02-11 17:54) [13]

Такой обработчик я уже пробовал:
if DM.Org.State in [dsEdit, dsInsert] then DM.Org.Post;
DM.Org.Close; DM.Org.Open; А на BeforeClose датасета вешаю обработчик разноски кэшированных данных в базу. Т.е. получается когда пост вызывается неявно (переходом на другую строку) или нажмешь enter после изменения все OK. А выдача поста программно не проходит :(


 
Desdechado ©   (2005-02-11 18:36) [14]

почему не проходит? только потому, что ты его в комбинации с Close использушь? так разнеси...



Страницы: 1 вся ветка

Форум: "Базы";
Текущий архив: 2005.03.13;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.47 MB
Время: 0.042 c
1-1109521083
randomize
2005-02-27 19:18
2005.03.13
RSA - В Delphi


1-1109667772
Димон
2005-03-01 12:02
2005.03.13
Выяснение причины сообщения "A component named . already exists"


6-1105520475
stone
2005-01-12 12:01
2005.03.13
Параметр lpszProfileName в MapiLogOn


9-1102850191
DeadMeat
2004-12-12 14:16
2005.03.13
Цена моделей


1-1109607392
Шурка_прогер
2005-02-28 19:16
2005.03.13
аналог Static в Делфи?





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский