Студопедия.Орг Главная | Случайная страница | Контакты | Мы поможем в написании вашей работы!  
 

Общие сведения о TDBSumList



Вы можете использовать TDBSumList для подсчета общего количества записей в TDataSet'е с динамическим отсаживанием изменений. Установите свойство DataSet в DBSumList'е для которого вы хотите считать и напишите обработчик события SumListChanged для описания действий после того как суммы в TDBSumList'е будут изменены. TDBSumList имеет свойство SumCollection, которое представляет собой контейнер для объектов TDBSum. Каждый объект TDBSum задает свойства подсчета агрегированного значения. Свойства FieldName и GroupOperation определяют имя поля и тип агрегированного значения, SumValue содержит текущее агрегатное значение.

Специальный подтип TDBSumList'а встроен в компонент DBGridEh.

Как это работает и почему SumList иногда рассчитывает агрегатные значения некорректно.

Data-aware компоненты взаимодействуют с dataset'ом через объект TDataLink. TDataLink не имеет свойств или событий для динамического отслеживания изменений в датасете. Например, когда удаляется запись из dataset'а, у всех объектов TDataLink срабатывает событие deDataSetChange (оперделяющее что Весь датасет изменился) и мы не может определить какое именно зименение произошло в датасете, удалилось ли одна запись или изменился весь датасет. Что бы не пересчитывать все значение в датасете при небольших изменениях TDBSumList переопределяет следующие события dataset'а: OnAfterEdit, OnAfterInsert, OnAfterOpen, OnAfterPost, OnAfterScroll, OnBeforeDelete, OnAfterClose, но появляются следующие проблемы, такие как:

Назначение этих событий в runtime деактивизируйте SumList.

При некоторых условиях SumList может выдавать ошибку нарушения доступа (exception of access violation). SumList пробует вернуть события dataset'у, но dataset уже удален. Подобная ситуция случается, когда SumList (или grid) и dataset расположены на разных формах (в разных DataModul'ях). В данной ситуации попробуйте деактивировать SumList перед тем, как форма либо DataModule с dataset'ом будут удалены.

SumList не сможет отследить изменения в dataset'е, если вы используете методы SetRange или ApplyRange. Вызывайте SumList.RecalAll после использования этих методов.

SumList не сможет отслеживать изменения в dataset'е для detail-dataset в не-BDE dataset'ах. Вызывайте SumList.RecalAll после изменения активной записи в master dataset'е.

Так же в других случаях если вы видите, что при некоторых условиях SumList рассчитывает значения некорректно, вызывайте метод RecalAll.






Дата публикования: 2014-11-28; Прочитано: 587 | Нарушение авторского права страницы | Мы поможем в написании вашей работы!



studopedia.org - Студопедия.Орг - 2014-2024 год. Студопедия не является автором материалов, которые размещены. Но предоставляет возможность бесплатного использования (0.005 с)...