Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Процедура в Oracle 
:(
    Опции темы
dolby
Дата 23.1.2012, 02:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 31
Регистрация: 23.2.2008
Где: Минск

Репутация: нет
Всего: нет



Здравствуйте!
У меня есть задание:

Создайте процедуру определения самых активных подписчиков для отделений связи за последнее полугодие.
-  Сведения о найденных подписчиках выдавайте на экран по отделениям связи и в алфавитном порядке ФИО внутри каждого отделения.
- Номера  отделений и найденное количество самых активных  подписчиков  для каждого сохраните в промежуточной таблице.

Мне если честно не совсем понятно как в PL/SQL создать промежуточную таблицу. Не получается =(
Про активных подписчиков. Я выбираю из таблицы подписчиков за последние полгода с помощью курсора. Получается надо использовать еще один, чтобы найти максимальное количество подписок?
Помогите, пожалуйста, хотя бы примером.

SQL
create or replace procedure "ACTIVE_SUBSCRIBER"
is


CURSOR id_cur IS
    SELECT код_подписч
    FROM Бланк_подп WHERE (extract(year from дата_подп) = (select extract (year from sysdate) from dual ) or (extract(year from дата_подп) = (select extract (year from sysdate) from dual) style='color:orange'>-1)) AND (extract(month from дата_подп) = (select extract (month from sysdate) from dual) or ((extract(month from дата_подп) > (12-6+(select extract (month from sysdate) from dual)) AND extract(month from дата_подп) < 12)));

TYPE table_ID IS TABLE OF NUMBER 
    INDEX BY BINARY_INTEGER;

mas_id table_ID;


i number;
nothing exception;    
    
begin i := 0;    
DBMS_OUTPUT.ENABLE;



DBMS_OUTPUT.put_line('good');        
        
OPEN id_cur;

FETCH id_cur INTO mas_id(i); IF not(id_cur%FOUND) THEN
raise nothing;
end IF;

LOOP  
    i := i+1;
    FETCH id_cur INTO mas_id(i); EXIT WHEN id_cur%NOTFOUND;
    
END LOOP;

CLOSE id_cur; 
DBMS_OUTPUT.put_line(mas_id(0));     
DBMS_OUTPUT.put_line('good');        
        
EXCEPTION 
    WHEN nothing THEN
    DBMS_OUTPUT.put_line('No such subscriber'); 

      
end;​ 

PM MAIL ICQ   Вверх
Zloxa
Дата 23.1.2012, 10:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 37
Всего: 161



Цитата(dolby @  23.1.2012,  02:10 Найти цитируемый пост)
Мне если честно не совсем понятно как в PL/SQL создать промежуточную таблицу. 

Мне, если честно, - тоже. 
Я знаю что такое таблицы, глобальные временные таблицы, что такое pl/sql коллекции, что такое промежуточная таблица - не знаю. smile 
Цитата(dolby @  23.1.2012,  02:10 Найти цитируемый пост)
 выдавайте на экран

Тоже не совсем понятно что значит выдать на экран, если только вы не в формсах работаете smile  Оракл датабаза с экраном не работает. Вы же сохраняете результат в output buffer.

Цитата(dolby @  23.1.2012,  02:10 Найти цитируемый пост)
(select extract (year from sysdate) from dual

можно заменить просто на extract (year from sysdate), выборка из dual - лишняя

Цитата(dolby @  23.1.2012,  02:10 Найти цитируемый пост)
за последнее полугодие.

наверное правильнее было бы условие на последнее полугодие построить как-то так:
Код

  where дата_подп >= add_months(sydate,-6)

Хотя, конечно, понятие "последнее полугодие", может трактоваться многояко.
может быть и как то так:
Код

  where дата_подп >= add_months(trunc(sysdate,'YY'),(trunc((-1+extract (month from sysdate))/6)*6))

т.е. начиная с текущего полугодия (мог ошибиться в формуле)
Цитата(dolby @  23.1.2012,  02:10 Найти цитируемый пост)
Я выбираю из таблицы подписчиков за последние полгода с помощью курсора.

таки XXI век на дворе. Намного удобнее обходить неявный курсор
Код

  for i in (select field from ....)
  loop
    dbms_output.put_line(i.field);
  end loop;


Цитата(dolby @  23.1.2012,  02:10 Найти цитируемый пост)
 Получается надо использовать еще один, чтобы найти максимальное количество подписок?

нет, полагаю, можно обойтись и одним запросом, с джойном и группировкой. Однако строить запросы к неизвестной структуре - заведомо не благодарное занятие.



Это сообщение отредактировал(а) Zloxa - 23.1.2012, 10:50


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Oracle"
Zloxa
LSD

Данный раздел предназначен для обсуждения проблем с Oracle Database, другие продукты Oracle здесь не обсуждаются. Просьба при создании темы, придерживаться следующих правил:

  • при создании темы давайте ей осмысленное название, описывающее суть проблемы
  • указывайте используемую версию базы, способ соединения и язык программирования
  • при ошибках обязательно приводите код ошибки и сообщение сервера
  • приводите код в котором возникла ошибка, по возможности дайте тестовый пример демонстрирующий ошибку
  • при вставке кода используйте соответсвующие теги: [code=sql] [/code] для подсветки SQL и PL/SQL кода, [code=java] [/code] - для Java, и т.д.

  • документация по Oracle: 9i, 10g, 11g
  • книги по Oracle можно поискать здесь
  • действия модераторов можно обсудить здесь

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Zloxa, LSD.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Oracle | Следующая тема »


 




[ Время генерации скрипта: 0.0979 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.