Для подключения к источнику данных компонент использует свойство

property DBGonnection: TSQLConnection;

которое позволяет связать его с соединением TSQLConnection (см. выше) . Или свойство

property Connect ionName: string;

которое позволяет выбрать тип соединения dbExpress напрямую.

При этом у компонента отсутствует механизм создания удаленного доступа к данным, представленный у компонента TClientDataSet свойствами RemoteServer И ProviderName.

После создания соединения с сервером БД можно определить тип используемой КОМэНДЬ1, ПОДОбНО компоненту TSQLDalaSet.

Тип команды определяется свойством

TSQLCommandType = (ctQuery, ctTable, ctStoredProc) ;
property CommandType: TSQLCommandType ;

А содержание команды задает свойство

property CommandText: string;

После этого компонент можно связывать с компонентами отображения данных, просматривать и редактировать данные.

Для передачи на сервер сделанных и сохраненных в локальном кэше изменений используется метод

function ApplyUpdates (MaxErrors: integer);
Integer;
virtual;

где параметр MaxErrors определяет максимально возможное число ошибок при сохранении. Обычно этому параметру присваивается - 1, что снимает ограничение на число ошибок.

Метод

fiinction Reconcile(const Results: OleVariant): Boolean;

очищает локальный кэш компонента от записей, которые успешно сохранены на сервере.

Отменить локальные изменения можно методом procedure CancelUpdates;

Обратите внимание, что в компоненте действуют традиционные методы набора данных Edit, Post, Cancel, Apply, Insert, Delete. Но ОНИ оказывают влияние только на записи, каптированные локально. Вы можете сколько угодно редактировать набор данных при помощи перечисленных методов, но они будут изменять только содержимое кэша. Настоящее сохранение на сервере осуществляется методом ApplyUpdates.

Данные между сервером и компонентом пересылаются пакетами.

Доступ к текущему пакету возможен при помощи свойства

property Data: OleVariant ;

Сделанные изменения содержатся в свойстве

property Delta: OleVariant;

При этом разработчик может регулировать размер пакетов. Например, при ухудшении соединения можно уменьшить размер пакетов. Размер пакета определяется свойством

property PacketRecords: Integer;

которое задает число записей в пакете. Автоматическое назначение пакетов включается

PacketRecords : = -1

Если значение PacketRecords равно 0, между клиентом и сервером пересылаются только метаданные.

Если свойство PacketRecords больше нуля, то необходимо вручную организовывать подкачку данных с сервера. Для этого используется метод

function GetNextPacket: Integer;

Для организации такой подкачки вполне подойдут методы-обработчики событий

property Bef oreGetRecords : TRemoteEvent;
property Af terGetRecords: TRemoteEvent ;

В компоненте TSimpleDataSet развиты средства работы с одиночными записями. Можно просмотреть общее число записей

property RecordCount: Integer; и номер текущей записи

property RecNo: Integer;

Размер одной записи сохраняется в свойстве

property RecordSize: Word;

Все изменения, сделанные в текущей записи, отменяются методом


⇐ Предыдущая страница| |Следующая страница ⇒

Программирование в Delphi 7



Новости за месяц

  • Октябрь
    2017
  • Пн
  • Вт
  • Ср
  • Чт
  • Пт
  • Сб
  • Вс