Воскресенье, 22 Дек 2024, 08:45
Uchi.ucoz.ru
Меню сайта
Форма входа

Категории раздела
Высшая математика [11]
Экономическая социология [95]
Основы Менеджмента [64]
Бухгалтерский учёт [157]
Философия [163]
Мировая Экономика [603]
Бизнес планирование [29]
Финансирование и кредитование инвест [105]
Ценообразование [46]
Гражданское право [196]
Права Человека [173]
Основы Маркетинга [207]
Основы энергосбережения [55]
Информатика [0]
Экология и устойчивое развитие [0]
Физика для студентов [0]
Основы права [0]
Политология [0]
Не стандартные примеры на Delphi [169]
Примеры на Delphi7 [108]
Алгоритмы [94]
API [110]
Pascal [152]
Базы Данных [6]
Новости
Чего не хватает сайту?
500
Статистика
Зарегистрировано на сайте:
Всего: 51653


Онлайн всего: 5
Гостей: 5
Пользователей: 0
Яндекс.Метрика
Рейтинг@Mail.ru

Каталог статей


Главная » Статьи » Студентам » Не стандартные примеры на Delphi

Поиск записи в больших таблицах
Вот один из советов читателей. Привожу письмо полностью.
Доброго времени суток, Валентин.

Прочитал Ваши "Советы по Delphi" - спасибо большое: понравилось и, главное,
помогло - никак не получалось нарисовать круглую форму. В свою очередь хочу
предложить на Ваш суд небольшую процедуру, которая мне очень помогла. Процедура
позволяет переходить на любую из записей в таблице (формат Paradox или DBase).
Необходимость в ней возникла, когда мне пришлось работать с таблицей размером в
10 и более тысяч записей у которой было несколько калькулируемых полей и полей
подлинкованных из объектов TQuery. При использовании метода TTable.MoveBy
программа медленно и печально замолкала (вообще-то она работала, но как?!).
Встретил я этот пример в технической документации Borland (2656), где
сравнивались функции Paradox Engine и BDE. Пример был написан на C. Вот его
интерпретация на Delphi:

uses

... BDE,
DBTables;
function MoveToRec(RecNo: longint;taSingle:
TDBDataSet): DBIResult;
var

CursorProps: CurProps;begin

Result:= DbiGetCursorProps(taSingle.Handle,
CursorProps);

if Result = DBIERR_NONE then begin
case TTable(taSingle).TableType of
ttParadox: Result:= DbiSetToSeqNo(taSingle.Handle,RecNo);
ttDBase: Result:= DbiSetToRecordNo(taSingle.Handle,RecNo);
else
Result:= DBIERR_NOTSUPPORTED;
end;{
case..}
//------------------------------------

if Result = DBIERR_NONE then
taSingle.Resync([rmCenter]);//------------------------------------

end{ if..}end;
Категория: Не стандартные примеры на Delphi | Добавил: Lerka (22 Ноя 2012)
Просмотров: 435 | Рейтинг: 1.0/ 5 Оштрафовать | Жаловаться на материал
Похожие материалы
Всего комментариев: 0

Для блога (HTML)


Для форума (BB-Code)


Прямая ссылка

Профиль
Воскресенье
22 Дек 2024
08:45


Вы из группы: Гости
Вы уже дней на сайте
У вас: непрочитанных сообщений
Добавить статью
Прочитать сообщения
Регистрация
Вход
Улучшенный поиск
Поиск по сайту Поиск по всему интернету
Наши партнеры
Интересное
Популярное статьи
Портфолио ученика начальной школы
УХОД ЗА ВОЛОСАМИ ОЧЕНЬ ПРОСТ — ХОЧУ Я ЭТИМ ПОДЕЛИТ...
Диктанты 2 класс
Детство Л.Н. Толстого
Библиографический обзор литературы о музыке
Авторская программа элективного курса "Практи...
Контрольная работа по теме «Углеводороды»
Поиск
Главная страница
Используются технологии uCoz