OLAP-отчет ActiveX: компонента v2.4.1.241 + ABC-анализ по любым измерениям

13.07.22

Разработка - Разработка внешних компонент

Компонента предназначена для построения OLAP-отчетов и ABC-анализа. OLAP (англ. online analytical processing, аналитическая обработка в реальном времени) — технология обработки информации, включающая составление и динамическую публикацию отчётов и документов. Используется аналитиками для быстрой обработки сложных запросов к базе данных, учета и анализа разнородных данных с целью отыскания аномалий и зависимостей, подготовки бизнес-отчетов по продажам, маркетингу.

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки для того, чтобы самостоятельно ее доработать для вашей базы данных. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в вашей базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование SM По подписке Купить один файл
PivotCubeAX v2.4.1.241.zip
.zip 7,64Mb
388
388
5 SM
Скачать Купить за 3 050 руб.
Видеопрезентация "Общее представление об OLAP-кубе.zip" (для PivotCubeAX 2.4.0.1)
.zip 2,33Mb
68
68
1 SM
Скачать Купить за 1 850 руб.
Видеопрезентация "Работа с измерениями в OLAP-кубе.zip" (для PivotCubeAX 2.4.0.1)
.zip 2,34Mb
58
58
1 SM
Скачать Купить за 1 850 руб.
PivotCubeAX v2.7.1.7z - исходники компоненты
.7z 5,18Mb
0
0
5 SM
Скачать Купить за 3 050 руб.

Основные возможности OLAP-отчета

1. Удобное отображение данных

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

3. Любая глубина вложенности группировок по строкам/колонкам

4. Фильтрация данных во время работы с кубом "на лету"

5. Простое интерактивное добавление формул

6. Разные типы агрегирования данных: суммирование, количество, среднее и т.д.

7. Программное управление внешним видом куба

8. Возможность работы с иерархическими измерениями

9. ABC-анализ по любым измерениям и показателям

 

Преимущества OLAP-технологий

1. Отчет не нужно переделывать для изменения группировок по строкам/колонкам.

2. Скорость и стоимость создания отчета OLAP намного ниже: достаточно построить грамотную выборку данных, все остальные задачи OLAP-технология возьмет на себя.

3. Скорость доработки отчетов OLAP выше до 60 % по сравнению с другими системами отчетности

4. OLAP-отчет можно сохранить - загрузка сохраненного отчета происходит очень быстро!

5. Один OLAP-отчет эквивалентен целому набору простых аналитических отчетов

 

Недостатки OLAP-технологий

1. OLAP не ориентирован на получение форм отчетности c произвольным дизайном - все OLAP-отчеты имеют одинаковый вид сводных таблиц

2. Некоторые пользователи визуально плохо воспринимают сводные таблицы

 

Преимущество данной разработки перед подобными:

1. Наличие удобного инсталлятора: он сам зарегистрирует все необходимое.

2. Наличие документции для разработчиков и пользователей.

3. Функции управления внешним видом куба и поддержка вывода иерархических измерений.

4. Встроенный ABC-анализ.

 

Почему не компоновка данных (актуально для 1С 8.x)

OLAP и "Компоновка отчетов 1C 8.x" - похожи, но это не одно и то-же.

1) Скорость изменения "точки зрения" на данные в OLAP намного выше, а следовательно - быстрее работает Ваш бизнес, быстрее можно принять управленческие решения (дополнительные сведения здесь http://www.cfin.ru/itm/olap/1c.shtml).

2) В OLAP-отчете можно в реальном режиме времени на каждый показатель вывести дополнительные данные - % вхождения, рейтинг, и т.д. Очень удобно!

 

Справочные материалы

Подробную информацию о возможностях компоненты вы можете получить из  файлов помощи (формат PDF). Примеры использования компоненты имеются для 1С 8.1 и для 1С 7.7.

 

Продукты аналогичной направленности


quick - infostart.ru - OLAP отчет в 1С7.7 одной строчкой кода! (без MSOffice)

Ukrandruha - infostart.ru - OLAP

JohnyDeath - infostart.ru - OLAP Анализ счёта

 

Благодарность за дельные советы, предложения и активное участие

and-blag

kittystark

JohnyDeath

 

Установка компоненты

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

 

См. также

Разработка внешних компонент Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Внешняя компонента позволяет печатать PDF файлы непосредственно из 1С, не используя при этом сторонних программ. Прекрасно работает на сервере, тонком клиенте и веб-клиенте. Основана на проекте PDFium из состава проекта Chromium/Chrome

1500 руб.

17.09.2018    35658    110    127    

113

Разработка внешних компонент Программист Платформа 1С v8.3 Конфигурации 1cv8 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 Платные (руб)

Внешняя компонента позволяет работать c TWAIN-совместимым оборудованием (сканерами, камерами) . Полностью совместима со стандартной TWAIN-компонентой из БСП и может применяться как ее замена без изменения вызовов, при этом может работать с 64-разрядной платформой, а так же имеет расширенную функциональность, например, сохранение результата непосредственно в PDF без использования сторонних утилит. Прекрасно работает на сервере, тонком клиенте и веб-клиенте (проверена работа в браузерах Google Chrome, Mozilla Firefox и Microsoft Internet Explorer).

3000 руб.

12.05.2020    26903    133    98    

85

Разработка внешних компонент Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Позволяет автоматизировать работу с картинками. С помощью компоненты можно измерять размер изображений, поворачивать их, наносить водяные знаки, конвертировать из одного формата в другой. Будет очень полезна для интернет-магазинов и всех, кому постоянно требуется работать с различными графическими форматами. Выполнена по технологии NativeAPI. Работает с форматами: jpg (jpeg), png, bmp, gif, tif

3600 руб.

02.09.2010    76454    71    255    

189

Разработка внешних компонент Телефония, SIP Программист Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

Внешняя компонента выполнена по технологии Native API для 1С 8.х, обеспечивает доступ к программным АТС Asterisk (FreePBX, Elastix) через AMI интерфейс. Через него можно управлять многими функциями Asterisk (определение номеров, перевод звонков, набор телефона и т. д.)

2400 руб.

04.05.2018    45767    117    66    

62

Разработка внешних компонент Механизмы платформы 1С Программист Стажер Платформа 1С v8.3 Бесплатно (free)

Некоторые практические аспекты создания внешних компонент на языке С++ для платформы 1С 8.3++.

26.01.2024    5499    starik-2005    32    

40

Инструментарий разработчика Разработка внешних компонент Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Пример взаимодействия 1С с Apach Kafka посредством внешней компоненты, разработанной на основе официальной библиотеки librdkafka (the Apache Kafka C/C++ client library).

22.11.2023    3357    70    ivan1703    26    

41

Разработка внешних компонент Программист Платформа 1С v8.3 Платформа 1C v8.2 Платные (руб)

Внешняя компонента, позволяющая посылать команды и получать ответы по GraphQL протоколу из 1С.Может быть использована при интеграции. В 1С работает на стороне "клиента".

4600 руб.

27.06.2023    2943    1    0    

2
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. cleaner_it 221 22.01.10 10:34 Сейчас в теме
Работа компоненты тестировалась на Win2003 и Win7. Для Win7/Win2003 цветовые схемы различаются. На рисунке цветовая схема Win7, для Win2003 она более темная.
2. JohnyDeath 301 22.01.10 11:01 Сейчас в теме
А зачем вообще зависимость от BDE?
4. cleaner_it 221 22.01.10 11:23 Сейчас в теме
(2) Насчет BDE смотрим руководство OLAP. В дальнейшем конечно планирую отказаться от него:)
(3) Напишу, просто времени не хватает
21. JohnyDeath 301 22.01.10 15:06 Сейчас в теме
(4)
Насчет BDE смотрим руководство OLAP. В дальнейшем конечно планирую отказаться от него

Что-то не увидел. Не туда смотрю?
Авансом +. Но для полного счастья еще нужно сделать очень много. Отказ от BDE - это первое и самое важное (ИМХО)
22. cleaner_it 221 22.01.10 15:12 Сейчас в теме
(21):

Метод CreateFactTable
Значение параметра ttParadox

Для работы с данным типом таблицы требуется установленный BDE
23. JohnyDeath 301 22.01.10 16:15 Сейчас в теме
(22) Спасибо, приблизительно понял.

А в сторону sqlite не хочешь посмотреть? Проект открытый. Очень шустрая встраеваемая БД, которая может хранится в памяти, что должно дать прирост в скорости чтения данных по сравнению с сохранением и чтением данных на локальный диск в базу ttParadox

Страничка враперов. На чём, кстати, писал свой проект?
24. cleaner_it 221 22.01.10 16:28 Сейчас в теме
(23) Можно попробовать sqlite. Проект писал на Delphi 6
25. JohnyDeath 301 22.01.10 16:32 Сейчас в теме
(24) тогда попробуй это http://www.yunqa.de/delphi/doku.php/products/sqlite3/index (вроде как больше всего советуют)
3. JohnyDeath 301 22.01.10 11:05 Сейчас в теме
Ну и заодно бы написал чем твоя разработка лучше/хуже разработок Ukrandruha и quick.
5. cleaner_it 221 22.01.10 11:58 Сейчас в теме
Открыл доступ к файлам для пользователей Инфостарт (изначально был только для разработчиков)
6. cleaner_it 221 22.01.10 12:07 Сейчас в теме
Нашел неточность в документации - метод AddDimension, параметр SizeData - это длина значения измерения, а не наименования. В следующей версии в документацию будет внесены соответствующие поправки
7. PowerBoy 3378 22.01.10 12:20 Сейчас в теме
Регистры 1С + СКД = OLAP !!!
Не вижу потребности в данной компоненте, разве что для 7.7
9. cleaner_it 221 22.01.10 13:44 Сейчас в теме
Выложил отличия от других разработок подобной направленности "Отличия от других разработок.pdf"

(7) Каждому свое, ИМХО СКД и OLAP решают разные задачи. Скорость изменения внешнего вида OLAP выше. Присутствует интерактивное добавление формул в куб, а также вывод НЕ ТОЛЬКО значения, но и при надобности процентов на колонку/строку, ее ранга и прочих вкусностей. А как-же возможность быстрого ABC-анализа (и такие вещи OLAP способен решать за считанные секунды)? А в СКД - возможность создания форматированного макета и вывода графиков наравне с таблицами. В любом случае мой опыт подсказывает, что для аналитиков OLAP намного удобнее
8. Gamm 13 22.01.10 13:42 Сейчас в теме
PowerBoy 22.01.2010 12:20:31
Регистры 1С + СКД = OLAP !!!
Не вижу потребности в данной компоненте, разве что для 7.7

Всё таки для перестройки изменения порядка аналитик в отчете СКД придется снова ждать получения данных, а плюс OLAP в более быстром получении результата.
10. tango 543 22.01.10 14:05 Сейчас в теме
а почему перем - экспорт?
Перем Куб Экспорт;
11. tango 543 22.01.10 14:07 Сейчас в теме
а какого-нибудь серверного варианта нет, чтоб на каждой юзерской машине не ставить?
15. cleaner_it 221 22.01.10 14:33 Сейчас в теме
(11) подумаю, вроде как имеется такая возможность - запуск ActiveX с удаленной машины. В HTML ведь используют ActiveX, и для этого его не требуется устанавливать
16. tango 543 22.01.10 14:50 Сейчас в теме
(15) прокомменть, пожалуйста, чего это я скачал у производителя?
Прикрепленные файлы:
17. cleaner_it 221 22.01.10 14:55 Сейчас в теме
(16) ActiveX компоненту, которую предлагает использовать PivotCube (они же ее разработчики). Куб к сожалению заполняется только SQL-запросами, заполнить ее из 1С будет более чем затруднительно.
12. tango 543 22.01.10 14:08 Сейчас в теме
13. tango 543 22.01.10 14:13 Сейчас в теме
ну, вот, блин, похвалил...
{Форма.Форма(22)}: Ошибка при вызове метода контекста (AddDimension): Произошла исключительная ситуация (PivotCubeAXLibraryCleaner.OLAP): Table: Cannot perform this operation on an open dataset
Куб.AddDimension("Измерение1","Измерение 1",101);
по причине:
Произошла исключительная ситуация (PivotCubeAXLibraryCleaner.OLAP): Table: Cannot perform this operation on an open dataset
Прикрепленные файлы:
14. cleaner_it 221 22.01.10 14:29 Сейчас в теме
(13) это происходит, когда куб построен, и его пытаются создать еще раз. для исправления этой ситуации я сделал метод CubeDeactivation, попробуй применить его перед созданием измерений, я его в тестовой обработке не применяю
18. cleaner_it 221 22.01.10 14:57 Сейчас в теме
Собственно говоря, моя компонента ActiveX создана на основе PivotCubeVCL, а не PivotCubeX
19. Saint 22.01.10 14:58 Сейчас в теме
Поправьте меня если я не прав, но разве сводные таблицы в 1С выполняют не аналогичную задачу?
20. cleaner_it 221 22.01.10 15:01 Сейчас в теме
(19) Не совсем. Да, внешний вид похож, но возможности совершенно другие, у OLAP их больше на порядок
26. cleaner_it 221 27.01.10 15:36 Сейчас в теме
Перед выходными выложу новую версию (возможно, переведенную на SQLite). Надеюсь, будут закончены практически все заявленные в предыдущей версии функции: загрузка/выгрузка/сортировка/группировка "parent-child"
29. cleaner_it 221 14.02.10 07:42 Сейчас в теме
(26) Никак не могу собраться дописать руководство:) Уже много чего сделал, а выложить без руководства не могу:(

В частности, реализована прозрачная работа с иерархическими измерениями (чего нет ни в одной из подобных разработок, где используются только линейные списки), добавлены и протестированы примеры работы с HTML (в том числе с автоматической установкой ActiveX на ПК клиента), 7.7 (с привязкой к краям формы), 8.2 (управляемые формы + web-сервер).

P.S.: На SQLite перевод будет не скоро, сначала надо в нем хорошенько разобраться (он однонаправленный, и не могу пока найти компонент для визуального просмотра таблиц БД SQLite на форме компоненты)
27. wolfsoft 2421 13.02.10 11:43 Сейчас в теме
Я правильно понимаю, что компонента PivotCubeVCL - платный компонент?
28. cleaner_it 221 14.02.10 06:05 Сейчас в теме
Да, он платный. Но никаких ограничений, кроме всплывающего окошка о необходимости регистрации (один раз, сразу после построения куба) нет, функционал полный
30. cleaner_it 221 03.04.10 04:19 Сейчас в теме
Выпускаю в свет новую версию компоненты - 2.3.1 (предыдущая была - 2.2.0.2).
Обновлены: документация, компонента.
Изменен список файлов для скачивания.

PS: Большая часть хотелок, которые я хотел реализовать - реализованы, удобство использования увеличено в разы:)
31. cleaner_it 221 21.04.10 11:18 Сейчас в теме
Инфостартовцы! Вы хоть напишите, в каких программах пригодился вам OLAP. Интересно:)
32. cleaner_it 221 13.05.10 06:53 Сейчас в теме
Накладочка вышла. В файле "FULL OLAP v2.3.1.zip" файл с руководством был выложен неправильный. Сегодня исправлю
33. brr 183 13.05.10 17:44 Сейчас в теме
А с печатью у нас как обстоят дела?
34. cleaner_it 221 14.05.10 10:56 Сейчас в теме
(33) Хотите - из Excel печатайте, хотите - используйте стандартную печать (в руководстве написано только про стандартную печать).

PS: "FULL OLAP v2.3.1.zip" я перевыложил
35. kittystark 15 14.05.10 18:31 Сейчас в теме
класс !!!
но есть пожелания/замечания
1. под 7.7 ничего не происходит при вызове Куб.CollapseAll(1,1) или Куб.ExpandAll(1,1)
(была создана иерархия по справочнику номенклатуры)

2. хотелось бы чтобы были реализованы "оригинальные zCube.dll" методы, типа TopPanelVisible(...), MapSave(...), MapLoad(...), MapSwap() и др. - подсмотрены в оригинальном HTML примере, а лучше сразу "сделать мост" ко всем оригинальным методам/свойствам

3. при использовании "оригинальной" компоненты ("PivotCubeX") в HTА, также как и при использовании этой разработки под 7.7, при нажатии маленькой кнопочки "стрелки вверх-вниз" в области "Измерения"и в области "Колонки" - "мелькают" и затем пропадают все отображаемые данные (как будто бы куб пустой; в области строк при щелчке на такой же копке - все нормально), перерисовка производится при клике мышью в области данных/при прокрутке мышинного колеса/при щелчке на соседней кнопке (как квадратик, аля кнопка "развернуть"), можно как-то вылечить ?

4. чего-то не пойму как должен график выводиться

5. можно ли как-то программно из 4-х вкладок оставлять только 1-ю, имхо, пользователям последние 3 могут быть не нужны, да простит меня автор за "наезд" на вкладку "о программе", а то как-то не прикалывает формировать куб и сохранять его с помощью этой компоненты, а потом работать с ним через "оригинальную" компоненту

6. новую версию архива еще не смотрел, но в руководстве.pdf методы AppendRecordHierarchical(), SetValueHierarchical(), PostRecordHierarchical() было бы не плохо подробно описать
36. cleaner_it 221 17.05.10 06:41 Сейчас в теме
(35) спасибо:) а где плюсик?

1. Эти методы работают только для линейных списков, для иерархических списков этот метод не работает (и пока не знаю, как он будет работать при смешанном режиме отображения "линейные+иерархические списки").

2.
а) Собственно, компонента и является тем самым "мостом", а просто говоря - оберткой.
б) У оригинальной компоненты некоторые методы дублируются - для куба и для карты клеток (я всегда реализовываю метод куба), при этом наименования куба и карты клеток могут отличаться
в) "оригинальный HTML пример" может быть только у PivotCubeX, я использую PivotCube VCL, наименования методов у них немного различаются. Если найду аналоги методов, указанных вами, то добавлю их

3) Эта кнопочка называется "Отображение/скрытие фильтра". Воспроизвести ситуацию, подобную вашей, у меня не получилось. Какую версию компоненты вы используете? Если не трудно - пришлите выгрузку куба. И описание системы тоже - терминал или нет, сколько памяти, и т.д.

4) На текущий момент нужно заново выбрать значения "Serie type", "pvcRows", "pvcMeasures", потом нажать кнопку "Обновить график". В следующем релизе работа с графиком будет упрощена и более прозрачна

5) А как-же "О программе":( Я так старался... Впрочем, подумаю

6) Тогда стоит посмотреть новую версию: методы AppendRecordHierarchical(), SetValueHierarchical(), PostRecordHierarchical() не нужны
37. kittystark 15 17.05.10 12:14 Сейчас в теме
а, ну да... , плюсанул :D

1. сорри, оказывается методы CollapseAll() и ExpandAll() работают!, и действительно независимо от иерархичности измерений, а работают они если в области строк или колонок находится 2 измерения и больше (даже для иерархических измерений)
видимо для раскрытия иерархий что-то другое нужно вызывать (через Object Browser насчитал у zCube.IMap по 6 методов Expand/Collapse, но вряд ли они помогут)

2. пункт 2.б) пока для меня большей ясности не внес, поясню чего хотелось бы:
- ночью пересчитали и заполнили куб данными, сохранили на диск
- пользователи днем подгружают рассчитанный куб с диска (методы SaveToCube() и LoadFromCube() c этими задачами прекрасно справляются, хотя и "сбрасывают параметры просмотра")
- но вместо жестко предопределенного в коде порядка вызова методов PutToColumn()/PutToRow(), при загрузке воспользоваться выбором одной из ранее сохраненных карт (файлики *.zcd), будь то дефолтная "настройка" или один из "более других" вариантов срезов куба, сохраненных пользователем (со своими любимыми измерениями/фильтрами/перегруппировками иерархий и т.п. - типа "отчет" такой-то)

у PivotCubeX есть методы MapSave(), MapLoad() как это сделать в твоей компоненте - поясни плиз...

3. vista home ed sp1, локально не в терминале, 2Гб оперативки, oleview.exe выдал:
PivotCubeX control: version = 3.37; TypeLib: 3.25 = PivotCubeXLib library
OLAP Active X 2.2.0.2 [cleaner]: version 2.2; TypeLib: 2.2
приаттаченная выгрузка для PivotCubeX - сформирована HTML-кой из C:\Program Files\PivotCubeX\Data\cubedemo.mdb, по кнопкам Activate/Save cube

...

6. только что качнул последний полный архив, в "примере программного кода.pdf" в процедуре ЗаполнитьИерархическуюСтруктуру эти методы присутствуют...
Прикрепленные файлы:
export_sample.cub
38. cleaner_it 221 18.05.10 10:07 Сейчас в теме
39. kittystark 15 18.05.10 18:29 Сейчас в теме
допустим есть "предопределенные" измерения Месяц, Квартал, Сезон с устоявшимся общепринятым принципом очередности элементов этих измерений (Янв .. Дек, Iкв .. IVкв и т.п.)

можно ли как-то до/после/во время заполнения куба данными задать ID элемента для таких измерений? а то получающаяся очередность при сортировке измерения по алфавиту не подходит, а сортировка по ключу - в итоге совпадает с сортировкой по алфавиту...

вроде бы OnCustomWrapData в access-примере для PivotCubeX решает эту проблему, но как добраться до этого события в 7.7 - пока для меня темный лес

или для этого нужно вводить иерархические измерения, без подчинений как таковых ?
и как это скажется на производительности?
40. cleaner_it 221 19.05.10 06:45 Сейчас в теме
(39) ид-шник назначать можно, но я обошелся тем, что перед наименованием ставлю номера, например:
01 - Январь
...
12 - Декабрь
41. kittystark 15 19.05.10 07:14 Сейчас в теме
(40) пример кода с назначением ID, пожалуйста, в студию

42. cleaner_it 221 19.05.10 07:55 Сейчас в теме
выложу в следующем релизе :)
43. kittystark 15 19.05.10 09:49 Сейчас в теме
обнаружилась фича: после создания формы, но ДО загрузки куба, панели измерений и колонок можно таскать мышью и они способны перескакивать на правый край

после добавления измерений, даже без заполнения, такого не происходит
44. cleaner_it 221 19.05.10 10:36 Сейчас в теме
Я знаю. Единственный способ обойти - блокировать доступ к элементам формы
46. kittystark 15 21.05.10 18:04 Сейчас в теме
(44)
PCX.RowToolbar.Options.Floating = 0
PCX.ColToolbar.Options.Floating = 0
PCX.DimToolBar.Options.Floating = 0
???
47. cleaner_it 221 24.05.10 03:19 Сейчас в теме
45. kittystark 15 20.05.10 16:30 Сейчас в теме
а как прогнозами пользоваться?
49. cleaner_it 221 19.06.10 17:03 Сейчас в теме
(45) что именно интересно про прогнозирование? Собственно, ничего особенного там нет, все зависит от вашей корпоративной политики и целей
57. kittystark 15 23.06.10 20:15 Сейчас в теме
(49) не понятно вообще, как эти "прогнозы" заюзать (если я правильно понял про группу элементов forecasting на форме редактора измерения)
58. cleaner_it 221 25.06.10 06:51 Сейчас в теме
(57) Насчет прогнозирования смотреть здесь:
PivotCube VCL Users Guide
(Пункт 2.1.3.4 Forecasting ability)
В планах использование этих возможностей пока не скоро. Народ и 30% существующего использовать не может. А вообще, там можно и ABC-анализ проводить очень быстро средствами OLAP

(56) Я помещаю обработку в макет, в нужном месте сохраняю на диск, открываю и использую. По мне, так реализация этого пункта вообще не нужна, но сильно уж просят:)
60. kittystark 15 25.06.10 10:12 Сейчас в теме
(58) Пункт 2.1.3.4 прочел, хотелось бы менять ConsequentName PrecedingName, т.к.
PivotCube.lng не дает таких возможностей

существует ли возможность реализовать свой алгоритм расчета для построения прогноза, например среднюю взвешенную, но со СВОИМИ весовыми коэффициентами

по поводу АВС-анализа пожалуйста подробней

мы под 7.7 конечно без макетов, а при ночном пересчете кубов просто несколько раз подряд вызывается ОткрытьФормуМодально с нужными параметрами, но вот если юзер банально хочет поменять период, то либо форму закрывай-открывай, либо надо фиксить «Cannot perform this operation on an open dataset»

кстати, у меня было замечено следующее: если несколько раз подряд открывать форму, формировать куб, закрывать форму, то процесс 1с-ки постепенно отжирает оперативную память не освобождая ее, т.е. со штатных 90-100 Мб только одними кубами можно постепенно доползти до 700Мб (дальше проверять не стал)
вопрос: а как нужно грамотно высвобождать ресурсы при закрытии формы ?
61. cleaner_it 221 25.06.10 10:23 Сейчас в теме
(60) По поводу ABC - это как сам закончу разбираться. То же самое с прогнозированием:)

Под 7.7, конечно, надо фиксить «Cannot perform this operation on an open dataset». Тут без вариантов.

При закрытии формы память я освобождаю, но подобного теста на 7.7 я не проводил (на 8.1 замечено не было) - очень интересно, буду проверять (возможно, закрытие окна 1С 7.7 вовсе не означает закрытия формы Delphi, как я считал)

PS: Есть желание показать сообществу "Пример использования OLAP ActiveX для 1С 7.7"?
72. kittystark 15 07.07.10 10:15 Сейчас в теме
из созревших идей:
1. запрещать некоторым пользователям открывать окно "редактор измерения" для конкретного измерения, смысл - сначала программно накладываем фильтрацию (переводом часть item'ов в репозиторий), а потом запрещаем менять фильтр, отсюда можем получить частичный доступ пользователя к информации

у себя реализовал через WShell.appActivate и SendKey, это решение хоть и действенно, но ч/з одно место, вот если бы "кнопке с треугольником вниз" измерения можно было прикрутить нечто вроде enabled-свойства - было бы классно

2. не плохо было бы организовать через Обработку Внешнего События реакцию на клик мышью в ячейке измерения/меры

кстати по поводу русификации ConsequentName, PrecedingName в (60) - вопрос решил
73. cleaner_it 221 07.07.10 10:39 Сейчас в теме
(72)
"1. ... " - вполне резонно, но здесь лучше учитывать права при заполнении куба - чтобы не нужные ему данные просто не попадали в отчет. Может, есть и другие причины реализации такого функционала?
"2. ... " - сам давно об этом думаю, хочу расшифровку сделать, но там события, как ты говоришь, "через одно место". Со временем, думаю, появится:)

74. kittystark 15 07.07.10 13:45 Сейчас в теме
(73) думал я об этом...
сейчас у меня схема такая: вечером, когда никого в базе нет, через виндовый шедулер в определенное время запускается vbs-скрипт, создающий V77.Application и запускающий обработку с использованием твоей компоненты (несколько раз с разными периодами), на выходе имеем несколько обновленных *.cub файлов, за разные периоды и с разными наборам измерений, но измерение "проект" (читай "менеджер") везде заполняется одинаково

на следующий день пользователи запускают другую обработку и ... юзают эти файлики через отдельно запускаемый HTML Application (*.hta ) со встроенной в него "оригинальной" компонентой, не тратя по 2 часа на расчет данных (база за 2,5 года), после выбора и загрузки файла куба производится принудительная фильтрация по измерению "проект" в зависимости от "прав на кубы" (почему юзается оригнальная компонента - отдельная песня)

ПРИЧИНЫ: честно говоря, меня не прикалывает на каждого юзера формировать по несколько "фамильных" кубов, юзеров-то много, сколько это будет по времени - даже испытывать не стал, но по прикидкам тоже много

плюс еще «Cannot perform this operation on an open dataset» с диалогом «PivotCube demo» портят всю картину (борьба с последним через wshell.AppActivate и SendKey происходит с переменным успехом :) )

для тех кто будет запускать OLAP.hta из прилагаемого архива: подразумевается расположение *.cub файлов в том же каталоге где и сам OLAP.hta, после загрузки куба при подведении курсора мыши на самый правый край - должно появиться меню, хелпик в разработке - можно прилепить свой, демо ролики - твои
Прикрепленные файлы:
OLAP_hta.zip
78. cleaner_it 221 07.07.10 15:03 Сейчас в теме
(74) за hta'шник спасибо:) Я делал по другому - помещал выборку в индексированную таблицу 1cpp, которую затем можно сохранить в файл, а затем при необходимости восстанавливал ту версию куба, которая мне нужна. Но твой способ тоже ничего:)

PS: проблему твою понял, в твоем случае конечно принудительная фильтрация нужна. Куб - один, пользователей куба - несколько, у каждого пользователя - свой фильтр. Нормальная ситуация
76. cleaner_it 221 07.07.10 14:58 Сейчас в теме
(72) или имелось в виду убрать доступ к элементу, чтобы пользователь вообще не мог наложить СВОЕЙ фильтрации? Тогда пойму - чтобы подтасовки фактов не было (например, убрали из отчета "неблагополучных" клиентов)
79. kittystark 15 07.07.10 15:13 Сейчас в теме
(76) да, именно запретить пользователю менять фильтрацию и оставлять ее только в "разрешенном" виде

с этой целью пытался я воспользоваться PCX.CubeIntf.Dimension(i).DeleteKey(j), чтоб скрыть "не нужные"элементы, элемент измерения удаляется, но вот значения мер после этого становятся очень уж кривыми и всякие попытки пересчитать куб пока не возымели положительного результата, может подскажешь метод ?
80. cleaner_it 221 09.07.10 16:53 Сейчас в теме
(79) вроде сделал блокировку кнопки с треугольником вниз:) Как протестирую нормально, буду выкладывать новую версию компоненты
81. kittystark 15 09.07.10 17:10 Сейчас в теме
(80) дас ист комас - дас ист гуд, спасибо, ждемс
104. kittystark 15 13.07.10 19:15 Сейчас в теме
ну раз уж речь пошла про MS-продукт, так там есть такие штуки как защита размерности (по поводу (80) пока так и не увидел - подскажи, плиз), "custom rollups", "distinct count" (возвращаясь к (91),(94)), вот это бы реализовать :)

по поводу юзерских формул, так там поведение действительно бывает непредсказуемым, особенно если воспользоваться рекурсивной конструкцией "новая мера" = "новая мера"[prev by row] + что-то, а чтоб не ломали голову с составлением формул 2 варианта: сохранение/считывание, или "джентельменский набор" по кнопке/меню

кстати, а почему сохранению/считыванию карты куба вычисляемые меры абсолютно индифферентны?
105. cleaner_it 221 14.07.10 03:18 Сейчас в теме
(104) сделал, да что-то не работает:cry: к следующему релизу разберусь наверное. Насчет формул нужен конечно джентльменский набор.

"кстати, а почему сохранению/считыванию карты куба вычисляемые меры абсолютно индифферентны?" - не скажу, но с проблемой такой сталкивался еще в пору использования компоненты quick. Конечно, классно было-бы эту задачку решить.

По поводу MS: "Другой главной областью исправлений стал значительно улучшенный движок вычислений с поддержкой унарных операторов, пользовательских формул свертки (custom rollups) и многомерных выражений (cell calculations). Также новыми возможностями стали защита размерности, счет без повторов (distinct count), взаимодействие по HTTP, сессионные кубы, уровни группировки и др." - со всем этим еще разбираться нужно. То, что я об этом не говорю, не означает что этого нет, просто я об этом ничего не знаю:)
106. kittystark 15 14.07.10 10:05 Сейчас в теме
(105) quick кстати, отошел от использования PivotCube и перешел на HireCube в своем ReportEx, вот только в текущем состоянии там сохранение куба очень кривое, и пока не реализована поддержка иерархий измерений (хотя в демо хаера она есть), только эти 2 момента склонили чашу весов при выборе в твою пользу

ну и плюс еще твоя активность - проектик-то живой, развивается постепенно, за что тебе отдельное человеческое спасибо :)
107. cleaner_it 221 14.07.10 10:58 Сейчас в теме
(106) Мы с ним переписывались, я так понял, что главный козырь был - "бесплатность" HireCube, и потеря исходников предыдущей версии компоненты (пусть поправит, если я неверно понял)... А мне PivotCube понравился, я решил с ним поработать пока:)

PS: Проект развивается и будет развиваться :D
109. cleaner_it 221 15.07.10 15:35 Сейчас в теме
Ну вот, добрался:)
Теперь куб можно построить в рамках одной обработки и при наличии иерархических измерений

PS: Как только доделаю (80), так сразу выложу
110. kittystark 15 15.07.10 19:31 Сейчас в теме
(109) непременно ждемс

в доке есть следующий пример для вычисляемых мер
begin
var a;
var b;
func xy;
a = "Summa";
b = "Count";
Result = xy(a,b);
end

есть List of supported functions:
SQRT(value)
ABS(value)
SIN(value)
COS(value)
POWER(value, power)
POWER2(value)
LOG10(value)
LN(value)
EXP(value)
NEG(value)
Показать

не пойму про определение func xy;, как можно на основании существующих функций и арифметических операторов сворганить свою локальную функцию, скажем myF, чтобы потом при вычислении значения меры ее вызвать несколько раз, типа,
begin
func myF(x) <определение своей функции>
Result = myF(1) + myF(10) + myF(50)
end
111. cleaner_it 221 16.07.10 04:52 Сейчас в теме
(110) Обработчик событий нужно добавлять.

To calculate own function, you need to create own event handler


Записал в TODO, это хорошая возможность. Давно хотел сделать возможность задавать произвольные правила вычисления формул (например, чтобы не считались некоторые значения по заданному условию)
114. kittystark 15 16.07.10 10:28 Сейчас в теме
(111) ну да ладно, обойдемся пока без обработчиков, пусть код вычисления меры будет не красивый, но будет хотя бы функциональный

да и предполагалось это все задействовать для АВС-анализа, кстати (112), в этом АВС, на мой взгляд ничего сложного, можно даже с существующим функционалом назначать "категорию А/В/С", правда с одной оговоркой вместо А/В/С будут какие-нибудь числа, например 1/2/3 или 100/200/300 и дальше по аналогии можно будет совместить с такими же числами XYZ-анализа сложением

возни на программирование "кнопки" по формированию чистого АВС-анализа по одному показателю, для некоего измерения на пару-тройку часов
116. cleaner_it 221 16.07.10 12:54 Сейчас в теме
(114) Так ABC уже почти готов:)
(115) W7 x64 - не пробовал. Тестировалось на w2k3 x32, w2k3 x64, w7 x32, wxp x32. Разве есть проблемы с регистрацией? Просьба в таком случае прислать скриншот с ошибкой
117. Константин С. 669 16.07.10 14:12 Сейчас в теме
119. cleaner_it 221 16.07.10 15:03 Сейчас в теме
(117) попробуй вручную regsvr32 или regasm - будет работать? А я пока посмотрю особенности компилирования под 64-битные системы (в таком случае буду выкладывать две отдельные сборки)
121. cleaner_it 221 16.07.10 15:20 Сейчас в теме
118. kittystark 15 16.07.10 14:15 Сейчас в теме
(116) а у меня уже готов :) , я ведь для юзеров все в *.hta-шке делаю с оригинальным активиксом, может и от твоих стараний почерпну идеи для воплощения у себя
122. cleaner_it 221 16.07.10 16:29 Сейчас в теме
(118) у тебя на иерархических измерениях ABC нормально работает?
123. kittystark 15 16.07.10 18:11 Сейчас в теме
(122) да вроде бы нормально, проверь:
в hta-шке (см.(74)) нужно обновить функцию
	function add_my_calculated_measure( measure_name, formula, format ){
		var curr_measure = 0
		for(var i=0; i<PCX.MapMeasureCount; i++){
			if(PCX.MapMeasures(i).Name == measure_name){
				curr_measure = PCX.MapMeasures(i)
			}
		}
		if(!curr_measure){
			PCX.MapAddCalculatedMeasure( measure_name, 'begin Result = ' + kill_dup_spaces(formula) + '; end')
			curr_measure = PCX.MapMeasures(PCX.MapMeasureCount-1)
		}else{
			//вместо добавления новой меры с таким же именем - переопределяем формулу существующей
			curr_measure.CalcFormula = 'begin Result = ' + kill_dup_spaces(formula) + '; end'
		}
		curr_measure .FormatString = (format)?(format):("#,###.00")
		return curr_measure
	}
Показать


добавить чуток служебных функций:
	function remove_all_dimensions_from_row_col_toolbars(){
		//убираем все измерения из области колонок
		for(var i=PCX.MapColumnDimCount-1; i>=0; i--){
			PCX.MapRemoveDimension(PCX.MapColumnDimension(i))
		}	
		//убираем все измерения из области строк
		for(var i=PCX.MapRowDimCount-1; i>=0; i--){
			PCX.MapRemoveDimension(PCX.MapRowDimension(i))
		}
	}

	function getMeasureIndexByName( mes_name ){
		for(var i=0; i<PCX.MapMeasureCount; i++){
			if(PCX.MapMeasures(i).Name == mes_name){
				return i
			}
		}
		return null
	}
	
	function show_only_this_measures( separated_str ){
		var arr = separated_str.split('|')
		for(var i=0; i<PCX.MapMeasureCount; i++){
			var found = 0
			for(var j=0; j<arr.length; j++){
				if(PCX.MapMeasures(i).Name == arr[j]){
					found = 1
				}
			}
			PCX.MapMeasures(i).Visible = found
		}
	}
Показать


ну и собственно изюм:
function get_category_formula( k1, k2, k3, max_A, max_B, TTL_perc_measure_name ){
		// выражение k1*H(max_A-x) + k2*H(x-(max_A+delta))*H(max_B-x) + k3*H(x-max_B+delta)
		// где H(x) - это функция Хевисайда, delta - достаточно малый параметр отступа от точки, равно:
		//  k1, при                       0 < x <= max_A, (т.к. значения x по определению нарастающего процента/доли - положительны)
		//  k2, при   max_A + delta <= x <= max_B
		//  k3, при                            x >= max_B + delta
		// возникают "слепые зоны", т.е. 2 промежутка где функция будет равна нулю:  (max_A; max_A + delta)  и (max_B; max_B + delta)
		delta = 0.0001
		s = ''+k1+'*H('+max_A+'-x) + '+k2+'*H(x-'+(max_A+delta)+')*H('+max_B+'-x) + '+k3+'*H(x-'+(max_B+delta)+')'
		//alert(s)
		
		//все встречающиеся функции Хевисайда, преобразуем к виду понимаемому парсером фромул
		s = s.replace(/H\(([^\)]+)\)/gi,'(   (1+($1)/ABS($1))/2    )').replace(/x/gi, TTL_perc_measure_name).replace(/\./gi,',')
		//log(s)
		return s
	}
	
	function ABC_analysis( analytic_measure_name, analytic_dimension_name ){			
		curr_measure = add_my_calculated_measure("TTL percent", analytic_measure_name + '[RUNNING_TOTAL_BY_COL] / '+analytic_measure_name+' [COLUMN] * 100')
		curr_measure = add_my_calculated_measure("ABC", get_category_formula(1,2,3, 70, 80, '"TTL percent"'), '##0' )
		show_only_this_measures( analytic_measure_name +"|TTL percent|ABC" )
		remove_all_dimensions_from_row_col_toolbars()
				
		PCX.MapAddDimensionToRows( analytic_dimension_name )		
		PCX.MapRebuild()
		PCX.MapSortByMeasure(0,getMeasureIndexByName(analytic_measure_name),1)
		PCX.MapRefreshData()	
	}

ABC_analysis('"Продажи (+НДС)"', "Номенклатура")
Показать
125. kittystark 15 16.07.10 19:13 Сейчас в теме
(123) :!: :!: :!: заметил еще что в комменте были съедены очень важные символы :!: :!: :!:

в функции get_category_formula() вместо (1+()/ABS())/2 должно быть (1+(<символ доллара>1)/ABS(<символ доллара>1))/2 :!: , а то иначе работать не будет
130. kittystark 15 20.07.10 11:31 Сейчас в теме
касаемо get_category_formula(...) (см.(123),(125))
в коде в исходном виде
s = s.replace(/H\(([^\)]+)\)/gi,'(   (1+($ 1)/ABS($ 1))/2    )').replace(/x/gi, TTL_perc_measure_name).replace(/\./gi,',')

...не учитываются 2 момента:
1. системные настройки (локаль), в частности текущий десятичный разделитель
2. измерение в своем наименовании может содержать точки/запятые
поэтому для большей устойчивости в работе лучше заменить этот код на следующий
s.replace(/H\(([^\)]+)\)/gi,'(   (1+($ 1)/ABS($ 1))/2    )').replace(/(\d+)([\.,])(\d+)/gi,'$ 1'+(1.5).toLocaleString().substr(1,1)+'$ 3').replace(/x/gi, TTL_perc_measure_name)

:!: ВНИМАНИЕ: после символов доллара никаких пробелов не должно быть, отредактируйте вручную при переносе кода к себе (издержки форума) :!:
131. cleaner_it 221 22.07.10 07:17 Сейчас в теме
(130) Пора свою публикацию делать:)

...

(123) И все-же при построении ABC на иерархических измерениях должны возникать проблемы. Например, имеется группа X, в ней два элемента- Y и Z. Y нужно отнести к категории А, а Z - к категории С. Если сохранять иерархию - то в обоих категориях нужно создавать иерархическую структуру, подобную имеющейся - то есть создавать в каждой категории группу X. В итоге должна получиться следующая структура:

Структура измерения ДО анализа:
X
-Y
-Z

Структура измерения ПОСЛЕ анализа:
A
-X
--Y
B
C
-X
--Z

Чем сложнее иерархическая структура, тем сложнее затем будет анализировать...

Я склоняюсь к мысли, что при проведении ABC-анализа группы необходимо убирать, т.е. преобразовывать иерархическое измерение к линейному списку. А затем, при необходимости, возвращать обратно
132. kittystark 15 22.07.10 11:04 Сейчас в теме
(131) согласен, я этот момент тоже прочувствовал и для себя проблем не вижу, т.к. были сделаны следующие выводы:
1. правильная постановка задачи, например для оптимизации складских запасов, именно такая как ты и говоришь - убрать группы, отсортировать, разнести по категориям
2. для проведения анализа на высоком уровне, по товарным группам в целом - предложенного решения вполне достаточно, хотя есть те самые нюансы

в виду того, что руки у меня не дошли до собственноручного написания включения/отключения групп (со времен (88)) возникают 2 ВРЕМЕННЫХ подхода: формировать 2 куба, отличающиеся только тем, что в одном есть иерархия, в другом нет; второй вариант - в один куб запихивать 2 измерения номенклатуры (с иерархией и без) и юзать подходящее

так что пока на скорую руку выкручиваемся как можем, а по хорошему нужно осваивать технику программирования не вычисляемой МЕРЫ АВС=1/2/3, она, помимо вышесказанного, дальше совмещения с XYZ пойти не даст, а нужна техника создания в рантайме (по меню/кнопке) новых (возможно нескольких) ИЗМЕРЕНИЙ ABC, т.к. такой подход позволит совместить данные анализа АВС [+XYZ] по одному "измерению+показателю" с 2-мя/3-мя и тд. АВС анализами по другим "измерениям+показателям",

и тогда возникнет возможность, например, определить, что один товар по сумме продаж относится к категории А, по рентабельности к В, а по оборачиваемости к С, ну а другие товары по этим же показателям отнести к ААА, ААВ, АВА и т.д.

имхо, перегруппировку измерения с созданием внутри него групп АВС лучше не рассматривать - геммора потом не оберешься
112. cleaner_it 221 16.07.10 06:31 Сейчас в теме
Чтобы работало (80), необходимо еще решить следующие проблемы:
1. Кнопка измерения становится недоступной совершенно (даже заменить кнопку этого измерения другим не получится)
2. При перестройке куба кнопка становится вновь доступной, т.е. нужно создавать обработчик события перестройки и вновь делать кнопку недоступной

Поэтому пожалуй я просто сделаю подписку "Проверка изменения фильтра", и если будет попытка изменения - запрещать. Несколько релизов этой возможности не будет, пока приоритет сдвинут на ABC-анализ и документацию
48. cleaner_it 221 19.06.10 17:02 Сейчас в теме
Выкладываю версию 2.4

Изменения по сравнению с версией 2.3.1

[*] - изменение
[+] - добавление
[–] - отказ/удаление

РЕАЛИЗОВАНЫ МЕТОДЫ:
[+] - Реализован метод SetIDByName (просьба kittystark)
[+] - Реализован метод SaveToHTML

ДОБАВЛЕНЫ СВОЙСТВА:
[+] - Добавлено свойство ShowRowTotals ['pvgtFixed', 'pvgtAtEnd', 'pvgtAtStart', 'pvgtDisabled']
[+] - Добавлено свойство ShowColumnTotals ['pvgtFixed', 'pvgtAtEnd', 'pvgtAtStart', 'pvgtDisabled']

ДОПОЛНЕНА ДОКУМЕНТАЦИЯ:
[+] - Описан метод AppendRecordHierarchical (Баг-репорт kittystark)
[+] - Описан метод SetValueHierarchical (Баг-репорт kittystark)
[+] - Описан метод PostRecordHierarchical (Баг-репорт kittystark)

НАСТРОЙКИ КОМПОНЕНТЫ ПО УМОЛЧАНИЮ:
[*] - Баг-репорт kittystark «После создания формы, но ДО загрузки куба, панели измерений и колонок можно таскать мышью влево-вправо». На текущий момент эта возможность убрана.

ДРУГОЕ:
[*] - Исправлено сворачивание раскрытых измерений при помещении любого измерения в строки и/или колонки (работает на линейных списках, при наличии иерархических измерений на верхнем уровне сворачивание происходит всегда)
[*] - изменено имя файла компоненты на PivotCubeAX.ocx (ранее ActiveFormProj1.ocx)
[+] - Добавлены типы итогов колонок и строк: pvgtFixed, pvgtAtEnd, pvgtAtStart, pvgtDisabled, см. «Атрибуты интерфейса»

А также:
1. Подправлена документация
2. Дополнен всеми новыми возможностями пример использования компоненты для 1С v8.1
50. cleaner_it 221 19.06.10 17:24 Сейчас в теме
Готовится к реализации в следующих версиях

[*] - изменение
[+] - добавление
[–] - отказ/удаление

Методы

Наименование метода
Описание
[+] SetWidthMeasure
Установка ширины колонок показателей
[+] SetWidthDimension
Установка ширины колонок измерений
[+] SetFilter
Программная установка фильтра
[+] ClearFilter
Программная отмена фильтра
[+] SortDimension
Сортировка измерений
[+] SaveToOpenOffice
Экспорт в Open Office
[+] LoadFromWEB
Загрузка куба, хранящегося на WEB-сайте
[+] LoadFromStream
Загрузка куба из потока данных
[+] SetWidth
Установка ширины формы компоненты
[+] SetHeight
Установка высоты формы компоненты

Другое
[+] - реализовать прогресс-бар для отображения процесса загрузки куба
[+] - доработать руководство пользователя OLAP (будет произведено деление документации на другие логические блоки, а так же выделение в отдельный блок используемых в компоненте типов — сейчас они описаны в одном блоке со свойствами компоненты)
[+] - доработать работу с графиком
[+] - добавить возможность работы компоненты на переносимой СУБД SQLite
[+] - добавить возможность сохранения/загрузки настроек положения/видимости колонок/строк/формул/показателей
[+] - реализовать возможность переформировывать куб в рамках одной и той-же обработки (исправить ошибку «Cannot perform this operation on an open dataset»)
56. kittystark 15 23.06.10 20:07 Сейчас в теме
(50)
из "Другое":
...
[+] - реализовать возможность переформировывать куб в рамках одной и той-же обработки (исправить ошибку «Cannot perform this operation on an open dataset»)

этого хотелось бы получить в первую очередь
218. Medvedik 05.05.12 10:31 Сейчас в теме
(50)
[+] - добавить возможность сохранения/загрузки настроек положения/видимости колонок/строк/формул/показателей

cleaner_it, эти планы похоронены, или как?
219. cleaner_it 221 05.05.12 13:59 Сейчас в теме
(218) Скорее сдвинуты по времени:) Сроки назвать не рискую, потому что задача не приоритетная
51. пользователь 19.06.10 17:32
Сообщение было скрыто модератором.
...
52. cleaner_it 221 20.06.10 07:49 Сейчас в теме
Поправка описания типов отображения итогов:

pvgtFixed
Значение типа отображения итогов зафиксировано - справа для колонок, снизу — для строк. При перемещении горизонтального/вертикального ползунков итоги сохраняют свое положение (аналог «Закрепить область» табличного документа или электронной таблицы OpenOffice (Excel))

pvgtAtEnd
Значение типа отображения итогов: в конце

pvgtAtStart
Значение типа отображения итогов: в начале

pvgtDisabled
Значение типа отображения итогов — не показывать
53. cleaner_it 221 20.06.10 09:28 Сейчас в теме
Выложил файл "Видеопрезентация "Общее представление об OLAP-кубе.zip" (для PivotCubeAX 2.4.0.1)"
54. cleaner_it 221 20.06.10 13:21 Сейчас в теме
Выложил файл "Видеопрезентация "Работа с измерениями в OLAP-кубе.zip" (для PivotCubeAX 2.4.0.1)"
55. cleaner_it 221 20.06.10 14:20 Сейчас в теме
Компонента заменена на версию 2.4.0.1 (наименование файла не изменилось, изменения по сравнению с версией 2.4 - чисто косметические)