-
Доброго времени суток!
Есть таблица с 60 полями, работаю через ADO.
Во избежании ошибки "Не удается найти строку для обновления. Некоторые значения могли быть изменены со времени последнего чтения" при событии FormShow использую
...TelTable.Properties['Update Resync'].Value:=adResyncAll;
Проблема вот в чем:
после сохранения созданой записи, она исчезает с набора данных и ее не видно в DBGrid'e.
Но реально в базе она сохраняется и после закрытия/открытия проги все данные видно.
В чем может быть причина?
Зараннее всем спасибо за советы
Да, и еще один нюанс: в БД Access была использавана функция реплики, могло ли это быть причиной?
-
> >Есть таблица с 60 полями
ОГО!
ADOQuery
CursorLocation: = clServer
CursorType := ctKeyset
-
> ADOQueryCursorLocation: = clServer
> CursorType := ctKeyset
Пробовал, правда с ADOTable, но тогда не работает сортировка (использовал SORT и по IndexField), а без нее никуда.
Выдает ошибку "текущий проводник не поддерживает необходимые интерфейсы для сортировки"
-
в AdoQuery -
select * from mytable
Order by FieldName
-
Спасибо попробую.
но вот только немного неудобно, переделывать многое прийдеться.
еще вопрос:
я пишу оболочку для работы с одной БД, и планируется сделать так, на серваке лежит база а на клиентских машинах только оболочка и доступ к базе идет через сеть, т.е. к одной базе подключаются несколько пользователей.
в даном случае при использовании CursorLocation: = clServer проблем не будет?
-
Недолжно.
Лучше вообще сделать редактирование отдельным окном и запросом, а в гриде только отображать данные.
Сортировать можно еще с помощью грида, только не стандартного а eh или cx
-
1. Заменить TADOTable на TADODataSet
2. Курсор клиентский, а не серверный - в данном случае он и нафиг не нужен, а тормозить будет
3. Для ЛЮБОЙ сортировки вполне достаточно св-во датасета Sort, при этом никакие индексы не нужны вообще
Редактирование и добавление рекомендую организовать не в самой сетке (в этом случае надо громоздить обработчики BeforeXXX/AfterXXX для проверки правильности заполнения данных пользователем), а в модальном окне с не DB-aware контролами (TEdit,TCombobox,TMemo..), а внесение изменений в таблицу выполнять отдельным TADOCommand/TADOQuery с последуещим переоткрытием датасета и поиском обновленной (добавленной) записи методом Locate
-
> [6] MsGuns © (20.08.08 15:47)
Если вместо последней запятой поставить жирную точку - абсолютно правильная рекомендация. 8-)
-
MsGuns спаисбо за совет, но в своем случаее желательно обойтись без "переоткрытия датасета и поиска обновленной (добавленной) записи методом Locate"
Забыл отметить как раз редактирование идет в отдельно окне через TEdit,TCombobox,TMemo.., а DBGrid использую только для просмотра, и в конце не буду его вообще использовать.
-
>AlexeyK (20.08.08 15:56) [8]
>MsGuns спаисбо за совет, но в своем случаее желательно обойтись без "переоткрытия датасета >и поиска обновленной (добавленной) записи методом Locate"
Коран запрещает ?
-
>Sergey13 © (20.08.08 15:53) [7]
>Если вместо последней запятой поставить жирную точку - абсолютно правильная рекомендация. 8-)
Чего вы так все панически избегаете переоткрытий на стабильных серверах ?
-
> [10] MsGuns © (20.08.08 16:12)
> Чего вы так все панически избегаете переоткрытий на стабильных серверах ?
Просто я их люблю и берегу, как и сеть. И стараюсь не нагружать пустой работой.
-
> Коран запрещает ?
> Чего вы так все панически избегаете переоткрытий на стабильных серверах ?
Дело не в паническом страхе, а в удобстве пользования, и условий использования программы!
-
> Пробовал, правда с ADOTable
В топку
-
> в AdoQuery
В топку
-
> CursorLocation: = clServer
Что на колени хочешь поставить сервер или клиента?
-
> а DBGrid использую только для просмотра, и в конце не буду
> его вообще использовать.
Ну и зачем тогда вообще вопрос, какая разница если сетки нет.
-
> Anatoly Podgoretsky © (20.08.08 16:39) [15]
> Что на колени хочешь поставить сервер или клиента?
Каким образом если это акцесс?
-
> Ну и зачем тогда вообще вопрос, какая разница если сетки нет.
Дело в том что к записи доступа нет после сохранения, сохранил - а ее нет!
а сетка просто для просмотра!
-
AlexeyK © (20.08.08 17:03) [18]
ну, а ты как сохранил, в том же датасете(который к сетке подключен) сделал POST?
-
Проблему решил по совету stas'a, использовав ADOQuery.
Спасибо stas!
но возможно есть ли какие-то другие решения с использованием курсора clUseClient?
-
stas © (20.08.08 17:05) [19]
да, том же датасете, но сохранял через DBNavigator
-
ну, так вот не сохранять в том же датасете.
через AdoCommand запрос на INSERT или UPDATE.
об это msguns в начале писал.
-
>но возможно есть ли какие-то другие решения с использованием курсора clUseClient?
Каким боком РЕШЕНИЕ зависит от курсора для акцеса ?
Почитайте что ли справку о кусоре в TADOConnection - тогда, возможно, исчезнут идиотские вопросы
-
>Sergey13 © (20.08.08 16:17) [11]
>Просто я их люблю и берегу, как и сеть. И стараюсь не нагружать пустой работой.
Глупости. На то он и сервер, чтобы "нагружать" его.
Кроме того, только переоткрытие гарантирует получение АКТУАЛЬНОГО состояния БД, включая изменения, внесенные другими пользователями.
А чтобы не провисала сетка, не надо гнать на клиент стотыщмильонов записей, тем более, что клиенту этому такие горы невозможно усмотреть физически.
-
> Каким образом если это акцесс?
В таком случае о каком CursorLocation: = clServer может идти речь?
-
Anatoly Podgoretsky © (20.08.08 17:41) [25]
Курсор создается на сервере т.е. в этом случае само ядро JET за ним следит, но для каждой машины это свое ядро и свой серверный курсор.
-
Думаю вопрос закрыт.
Всем большое спасибо!
-
> stas (20.08.2008 17:46:26) [26]
Кто то недавно обижался, мол какой сервер если его нет.
-
> [24] MsGuns © (20.08.08 17:38)
> Глупости. На то он и сервер, чтобы "нагружать" его.
Ключевым в моем посте было не "нагружать", а "пустой работой".
> Кроме того, только переоткрытие гарантирует получение АКТУАЛЬНОГО
> состояния БД
И сколько времени продолжается после открытия состояние актуальности?
-
> Во избежании ошибки "Не удается найти строку для обновления. Некоторые значения могли быть изменены со времени последнего чтения"
> при событии FormShow использую
> ...TelTable.Properties['Update Resync'].Value:=adResyncAll;
логичнее было бы использовать ключ, и обновление по нему... а это "немного" не то, не для этого.
-
Anatoly Podgoretsky © (20.08.08 17:41) [25]
Так как на каждой машине свой сервер и серверный курсор создается на сервере каждой машины, то сервер установкой серверного курсора на колени поставить неполучится.
-
> stas (21.08.2008 10:02:31) [31]
Как ты создашь серверный курсор без сервера?
-
а где в stas © (21.08.08 10:02) [31] я написал что сервера нет?
-
> stas (21.08.2008 16:13:33) [33]
Ищи, иначе не понятны претензии.
-
Anatoly Podgoretsky © (21.08.08 19:10) [34]
У тебя ко мне претензии.
А топикстартер сделал как я сказал у него все заработало и он забыл уже об этом вопросе.
-
Это у тебя ко мне почему то претензии, то у тебя Акцесс сервер, то нет.
-
Кроме того, я говорю о конструкции CursorLocation: = clServer, а не об Акцессе. Вопрос повторить?