+7 (495) 229-0436   shopadmin@itshop.ru 119334, г. Москва, ул. Бардина, д. 4, корп. 3
 
 
Вход
 
 
Каталог
 
 
Подписка на новости
Новости ITShop
Windows 7 и Office: Новости и советы
Обучение и сертификация Microsoft
Вопросы и ответы по MSSQLServer
Delphi - проблемы и решения
Adobe Photoshop: алхимия дизайна
 
Ваш отзыв
Оцените качество магазина ITShop.ru на Яндекс.Маркете. Если вам нравится наш магазин - скажите об этом Google!
 
 
Способы оплаты
 
Курс расчета
 
 1 у.е. = 92.01 руб.
 
 Цены показывать:
 
 
 
 
  
Новости, статьи, акции
 

Пользовательские функции аггрегации в Oracle

25.11.2009 10:10
Дмитрий Богомолов

Встретил сегодня вопрос на SQL.RU "Как запросом получить произведение значений всех предыдущих строк?", и решил попробовать создать собственную функцию аггрегации. Задача на самом деле проще простого, но редко когда решаемая. Итак...

Вступление.

Все используют функции аггрегации, такие как MAX, MIN, AVG, SUM и прочие, которые выполняют действие над некоторым массивом данных. Однако время от времени возникает необходимость, скажем, не сложить, а перемножить все значения поля в выборке. В данном случае нам на помощь приходит интерфейс ODCIAggregate.

Краткое описание.

Интерфейс ODCIAggregate имеет 4 метода:

  • Initialize
  • Iterate
  • Merge
  • Terminate
Чем же они занимаются? По порядку:
1. Initialize. Данный метод выполняет определенные действия перед началом вычислений.
2. Iterate. Собственно метод, выполняющий операцию над очередным значением из массива.
3. Merge. Метод, необходимый в случае распараллеливания выполнения расчета, когда весь массив бьется на части, а потом расчитанные по отдельности они объединяются. Так вот этот метод выполняет объединение пары результатов.
4. Terminate. Метод, заканчивающий расчеты и выдающий результат.

Кроме того необходимо объявить функцию, которая будет вызывать расчет аггрегатной функции.

Пример.

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

-- Создаем тип для вычислений
create type MultiImpl as object
(
multires NUMBER, -- результат
static function ODCIAggregateInitialize(sctx IN OUT MultiImpl)
 return number,
member function ODCIAggregateIterate(self IN OUT MultiImpl,
 value IN number) return number,
member function ODCIAggregateTerminate(self IN MultiImpl,
 returnValue OUT number, flags IN number) return number,
member function ODCIAggregateMerge(self IN OUT MultiImpl,
 ctx2 IN MultiImpl) return number
);
/

-- Создаем тело типа

create or replace type body MultiImpl is
-- Функция, выполняющая инициализацию объекта
static function ODCIAggregateInitialize(sctx IN OUT MultiImpl)
return number is
begin
sctx := MultiImpl(1);
return ODCIConst.Success;
end;

-- Функция, выполняющая расчет
member function ODCIAggregateIterate(self IN OUT MultiImpl, value IN number)
return number is
begin
  -- умножаем текущий результат на очередное значение
  self.multires := self.multires*value;
  return ODCIConst.Success;
end;

-- Функция, заканчивающая расчет
member function ODCIAggregateTerminate(self IN MultiImpl, returnValue OUT
number, flags IN number) return number is
begin
  returnValue := self.multires; -- Передаем результат в выходной параметр
  return ODCIConst.Success;
end;

-- На случай распараллеливания
member function ODCIAggregateMerge(self IN OUT MultiImpl, ctx2 IN MultiImpl) return number IS
begin
  -- Просто перемножаем результаты
  self.multires := self.multires*ctx2.multires;
  return ODCIConst.Success;
end;
end;
/

-- Ну и создаем функцию, которая будет вызывать аггрегацию
CREATE FUNCTION Multi (input NUMBER) RETURN NUMBER
PARALLEL_ENABLE AGGREGATE USING MultiImpl;
/

Итог.
Теперь пробуем использовать то, что получилось:
SQL> SELECT multi(col)
2    FROM (SELECT 2 AS col
3            FROM dual
4          UNION ALL
5          SELECT 3 AS col
6            FROM dual
7          UNION ALL
8          SELECT 4 AS col
9            FROM dual
10          UNION ALL
11          SELECT NULL AS col
12            FROM dual
13          UNION ALL
14          SELECT 7 AS col
15            FROM dual
16          UNION ALL
17          SELECT 8 AS col FROM dual) t;

MULTI(COL)
----------
1344

Ссылки по теме

  
Помощь
Задать вопрос
 программы
 обучение
 экзамены
 компьютеры
Бесплатный звонок
ICQ-консультанты
Skype-консультанты

Общая справка
Как оформить заказ
Тарифы доставки
Способы оплаты
Прайс-лист
Карта сайта
 
Бестселлеры
Курсы обучения "Atlassian JIRA - система управления проектами и задачами на предприятии"
Microsoft Windows 10 Профессиональная 32-bit/64-bit. Все языки. Электронный ключ
Microsoft Office для Дома и Учебы 2019. Все языки. Электронный ключ
Курс "Oracle. Программирование на SQL и PL/SQL"
Курс "Основы TOGAF® 9"
Microsoft Office 365 Персональный 32-bit/x64. 1 ПК/MAC + 1 Планшет + 1 Телефон. Все языки. Подписка на 1 год. Электронный ключ
Курс "Нотация BPMN 2.0. Ее использование для моделирования бизнес-процессов и их регламентации"
 

О нас
Интернет-магазин ITShop.ru предлагает широкий спектр услуг информационных технологий и ПО.

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

Хорошие отзывы постоянных клиентов и высокий уровень специалистов позволяет получить наивысший результат при совместной работе.

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



 

О нас

 
Главная
Каталог
Новинки
Акции
Вакансии
 

Помощь

 
Общая справка
Как оформить заказ
Тарифы доставки
Способы оплаты
Прайс-лист
Карта сайта
 

Способы оплаты

 

Проекты Interface Ltd.

 
Interface.ru   ITShop.ru   Interface.ru/training   Olap.ru   ITnews.ru  
 

119334, г. Москва, ул. Бардина, д. 4, корп. 3
+7 (495) 229-0436   shopadmin@itshop.ru
Проверить аттестат
© ООО "Interface Ltd."
Продаем программное обеспечение с 1990 года