Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.02.07;
Скачать: CL | DM;

Вниз

IB   Найти похожие ветки 

 
Bura ©   (2002-01-10 00:44) [0]

Господа, доброй ночи... У меня такой проблем. Данные отображаются в одной IBTable и в одной DefaulTransaction, подключенной к IBDataBase как DefaultTransaction, а изменяются в другой Trans. Как только я делаю Commit, в IBExpress все сразу видно, а в тех IBTable, которые отображают данные - нет. Никакой Refresh и Open/Close не помогают. Только после перезагрузки программы видно. Я понимаю, что все дело в разных транзакциях... Как правильно сделать, чтобы все было красиво? Можно, конечно все в одной транзакции, но вот не нравится мне, что DataSet закрывается... И хотелось бы, чтобы для изменения были одни данные, а для отображения - другие. Данные изменяются не пользователем, а программой, в одном пакете в 10 таблицах.
Спасибо за советы


 
kaif ©   (2002-01-10 01:09) [1]

Чтобы после Commit в одной транзакции Close/Open запроса в другой отобразил новые данные, нужно, чтобы другая транзакция имела изоляцию ReadCommitted. Для этого щелкни на компоненте IBTransaction дважды мышью и выбери нужный режим.
Чтобы Dataset не закрывался вместо Commit используй CommitRetaining. Тогда можно все в одной транзакции сделать.
Хотя в отдельной транзакции делать Update, возможно, имеет свои преимущества.


 
Bura ©   (2002-01-10 01:25) [2]

Спасибо, теперь понял от чего отталкиваться... :-)


 
Bura ©   (2002-01-10 01:43) [3]

>kaif
А как избежать Close/Open у DataSet... У меня таблицы долго открывается (ок. 25000 записей с большими символьными полями).
Когда я делал 3-х звенку на Paradox, все выполнялось гораздо быстрее с методом Refresh у TClientDataSet. Но, решил, что 3-х звенка - геморрой. Теперь, если каждый раз после обновления делать Close/Open, то некрасиво получается...


 
dymka ©   (2002-01-10 09:23) [4]

Это... если используешь клиент-серверную технологию - то попробуй отказаться от таких больших курсоров. Выводи порциями... Представь, что тебе придется эксплуатировать программу на узком сетевом канале. А рефреш у айби рефрешит только текущую запись. А чтобы обновить все, нужно переоткрыть набор, ведь тебе нужно перечитать данные с сервера, а какие данные изменились сервер не знает и только новая транзакция увидит их (Старая будет видеть свои версии данных, возможно уже не актуальные).



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

Текущий архив: 2002.02.07;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.026 c
1-18852
nikols
2002-01-22 11:06
2002.02.07
Кто нибудь знает, как из PDF файла извлечь сразу весь текст и графику?


6-18942
Deep
2001-11-10 04:25
2002.02.07
как сделать папку сетевой?


1-18903
Ольга
2002-01-22 17:18
2002.02.07
Delphi 6


6-18939
SemFLY
2001-11-18 01:18
2002.02.07
Ожидание соединения с интернетом ?!


3-18704
dim-
2002-01-09 12:35
2002.02.07
FreeReport