24.04.2017, 10:26 [+3 UTC]
в нашей команде: 1 917 чел. | участники онлайн: 6 (рекорд: 21)

:: РЕГИСТРАЦИЯ

:: консультации

:: задать вопрос

:: все разделы

:: правила

:: новости

:: участники

:: доска почёта

:: форум

:: блоги

:: поиск

:: статистика

:: наш журнал

:: наши встречи

:: наша галерея

:: отзывы о нас

:: поддержка

:: руководство

Версия системы:
7.41 (25.02.2017)

Общие новости:
23.02.2017, 09:51

Форум:
23.04.2017, 11:54

Последний вопрос:
23.04.2017, 22:28

Последний ответ:
24.04.2017, 07:09

Последняя рассылка:
24.04.2017, 01:45

Писем в очереди:
0

Мы в соцсетях:

Наша кнопка:

RFpro.ru - здесь вам помогут!

Отзывы о нас:
29.11.2009, 22:25 »
ale
Большое спасибо за ответ. К сожалению, у меня опыт работы с ПК полгода, мне 62 г. Поэтому как воспользоваться последним советом - мне затруднительно, но попытаюсь. Спасибо! [вопрос № 174678, ответ № 257069]
14.06.2011, 18:56 »
Polotenchikko
Вот это здорово! Polotenchikko в программе! )) спасибо!!! [вопрос № 183623, ответ № 267733]
21.11.2016, 20:30 »
svrvsvrv
Большое спасибо за помощь. Очень логичное и доступное объяснение. [вопрос № 190048, ответ № 274284]

РАЗДЕЛ • Basic

Создание программ на языке Basic.

[администратор рассылки: Андреенков Владимир (Профессор)]

Лучшие эксперты в этом разделе

Megaloman
Статус: Академик
Рейтинг: 393
mklokov
Статус: 4-й класс
Рейтинг: 88
PsySex
Статус: Профессионал
Рейтинг: 47

Перейти к консультации №:
 

Консультация онлайн # 137089
Раздел: • Basic
Автор вопроса: Upgrader
Отправлена: 16.05.2008, 15:55
Поступило ответов: 1

Здравствуйте!
Подскажите как на VBA в Access обновить список (длинная таблица) так, чтобы он не прокручивался в начало, а оставался как есть в том-же положиении (т.к. длинный, трудно искать нужную запись)

Обновляю так:
Список.Requery

Но при этом список прокручивается или вверх до конца, или на какую-нибудь совсем другую строку, а не та ту, которая была выбрана до этого (можно выделить только одну строку).
Подскажите что происходит, как сделать нормально?

Состояние: Консультация закрыта

Ответ # 223786 от Черников Игорь Владимирович

Здравствуйте, Upgrader!
При обновлении recordset-а курсор обычно возвращается в первую позицию, поэтому Вам нужно сначала запомнить на какой строке был курсор, а после обновления вернуть его на прежнее место. Это можно сделать так:

Function Refreshh1()
temp = recordset.Bookmark
recordset.Requery
recordset.Bookmark = temp
End Function

Недостаток этой функции в том, что если добавятся записи выше этой, то и курсор переместится вверх на количество таких строк. Но обычно записи добавляются в конец, если в запросе не указана сортировка по какому-нибудь полю.

Удачи!


Консультировал: Черников Игорь Владимирович
Дата отправки: 16.05.2008, 17:47

Рейтинг ответа:

0

[подробно]

Сообщение
модераторам

Отправлять сообщения
модераторам могут
только участники портала.
ВОЙТИ НА ПОРТАЛ »
регистрация »

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

Яндекс Rambler's Top100

главная страница | поддержка | задать вопрос

Время генерирования страницы: 0.13607 сек.

© 2001-2017, Портал RFPRO.RU, Россия
Авторское право: ООО "Мастер-Эксперт Про"
Калашников О.А.  |  Гладенюк А.Г.
Версия системы: 7.41 от 25.02.2017
Бесплатные консультации онлайн