Форум программистов, компьютерный форум, киберфорум Oracle
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
cancer27
1

SELECT ... FROM TABLE(My_CURSOR('param1', 'param2') ) t1 WHERE ...;

22.09.2009, 17:21. Показов 4303. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Вот две таблицы
Oracle 11 SQL Скопировано
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
CREATE TABLE MASTER_TABLE   
(   "ID" NUMBER NOT NULL ENABLE, 
    "TYPE" VARCHAR2(2 BYTE) NOT NULL ENABLE, 
    "OPEN_DATE" DATE NOT NULL ENABLE, 
     CONSTRAINT "MASTER_TABLE_PK" PRIMARY KEY ("ID")
);
/ 
CREATE TABLE DETAILS_TABLE
(   "MASTER_ID" NUMBER NOT NULL ENABLE, 
    "DETAIL_TYPE" VARCHAR2(2 BYTE) NOT NULL ENABLE, 
    "MONEY" NUMBER(10,2) NOT NULL ENABLE, 
    "ACTIVE_FROM" DATE NOT NULL ENABLE, 
    "ACTIVE_TO" DATE
   );
/
CREATE INDEX DETAILS_TABLE_I1 ON DETAILS_TABLE (MASTER_ID) ;
 /
CREATE INDEX DETAILS_TABLE_I2 ON DETAILS_TABLE (DETAIL_TYPE) 
/
Весь гугл прогуглил так и не нашел ответа ...

Пожалуйста посоветуйте, можно ли сделать такое, и если можн то какая будет производительность, т.е. а стоит ли вообще так делать!

Создаю пакет, где объявляю курсоры
Oracle 11 SQL Скопировано
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
CREATE OR REPLACE PACKAGE test AS
    CURSOR D1_CURSOR(byDate DATE) IS 
        SELECT d.master_id, SUM(d.money) AS DETAIL1
        FROM DETAILS_TABLE d
        WHERE d.master_id = master_id
          AND d.detail_type = 'd1' 
          AND d.active_from <= byDate  
          AND ( d.active_to > byDate OR d.active_to IS NULL) 
        GROUP BY d.master_id;
 
    CURSOR D2_CURSOR(byDate DATE) IS 
        SELECT d.master_id, SUM(d.money) AS DETAIL2
        FROM DETAILS_TABLE d
        WHERE d.master_id = master_id
          AND d.detail_type = 'd2' 
          AND d.active_from <= byDate  
          AND ( d.active_to > byDate OR d.active_to IS NULL) 
        GROUP BY d.master_id ;
END test;
/
show errors PACKAGE test ;
/
 
CREATE OR REPLACE PACKAGE BODY test AS
END test;
/
 
show errors PACKAGE test ;
/
1вый вопрос.
как можно вывести результат курсора в SELECT запросе...
что нибудь в роде
Oracle 11 SQL Скопировано
1
SELECT * FROM TABLE(test.D1_CURSOR(SYSDATE)) d1 WHERE d1.master_id = 1
и второй вопрос.

А можно ли написать запрос или объявить курсор типа
Oracle 11 SQL Скопировано
1
2
3
SELECT m.id, m.TYPE, d1.DETAIL1, d2.DETAIL2
FROM MASTER_TABLE m, TABLE(D1_CURSOR(SYSDATE)) d1, TABLE(D2_CURSOR(SYSDATE)) d2,
WHERE m.id = d1.master_id AND m.id=d2.master_id
или
Oracle 11 SQL Скопировано
1
2
3
4
5
CURSOR REPORT_CURSOR IS
  SELECT m.id, m.TYPE, d1.DETAIL1, d2.DETAIL2
 
 FROM MASTER_TABLE m, TABLE(D1_CURSOR(SYSDATE)) d1, TABLE(D2_CURSOR(SYSDATE)) d2,
WHERE m.id = d1.master_id AND m.id=d2.master_id;
и потом пользоваться им как в первом вопросе..???

мне просто нужны курсоры как представления, что исползовать их в запросах. я пытаюсь таким образом не дублировать код запросов, а то у меня тут около 8и отчетов, и все почтни одинаковы, только различаются в SELECT-e и GROUP BY...
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.09.2009, 17:21
Ответы с готовыми решениями:

Не передаются параметры в пхп (href='service.php?param1=$par1&param2=$par2')
У меня такая проблема: несколько файлов (допустим index.php и service.php) включают в себя файл меню (menu.php). В этом меню прописаны...

select s odnoi table, and insert v drygyjy table
privet! mne nado sdelat backup s ASP.NET, kogda stirayt DB, no na vsaki slychay mne nado soxranit ety table. backup ne poxodit, mne nado...

select from [TABLE OF]
Можно ли сделать select-запрос из переменной типа 'TABLE OF'. Или функции, возвращающей тип TABLE OF?

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
22.09.2009, 17:21
Помогаю со студенческими работами здесь

Table.Select И DataRow[]
String CmdLen = @&quot;SELECT b1.SERN, b1.DDATE, b1.TTIME, b1.LATT, b1.LONGT, b1.FROM_FLAG FROM BD_GBR b1 ...

Условие выборки select * from table, table1 where table.field like table1.field+'%'
Как в Оракле в условие выборки поставить такое: select * from table, table1 where table.field like table1.field+'%' т.е. в like, мне...

Multi select from same table and column
SELECT `tag`, `count` FROM `tags` WHERE `tag` IN (&quot;.implode(',', $tagsArr).&quot;) Пытаюсь сделать вот такой запрос, но он не работает (там...

insert into table values (select....
Здравствуйте, скажите, как заставить работать следующий запрос: insert into tg3.dbo.tg3hour values (getdate(),select avg() from ..) ...

Результат SELECT в виде 'table.field' = value
Здравствуйте! Подскажите, пожалуйста, есть ли стандартный способ средствами mysql (на худой конец php) получить результат следующего...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Сопоставление с образцом (Pattern Matching) в Python: Списки и словари
py-thonny 19.03.2025
Программисты любят, когда код говорит сам за себя. Представьте, что вы можете просмотреть структуру данных и мгновенно понять, что с ней делать — без сложных условий и вложенных проверок. Именно эту. . .
Работа с метаданными EXIF и JPEG в JavaScript
run.dev 19.03.2025
Работа с изображениями в веб-разработке нередко выходит за рамки простого отображения картинки. Современные задачи требуют глубокого понимания структуры файлов и умения манипулировать их внутренними. . .
Чеклист для Kubernetes в продакшене: Лучшие практики для SRE
Mr. Docker 19.03.2025
Когда сталкиваешься с запуском Kubernetes в продакшене, невольно задаешься вопросом: почему то, что так гладко работало в тестовой среде, вдруг начинает вызывать головную боль на боевых системах?. . .
Разработка продвинутого ИИ в Unity с использованием Behavior Graph
GameUnited 19.03.2025
В разработке игр искусственный интеллект персонажей часто становится тем элементом, который превращает хорошую игру в выдающуюся. До недавнего времени разработчикам под Unity приходилось либо писать. . .
Словари в Python: методы работы, оптимизация, сериализация
py-thonny 19.03.2025
Каждый хотя бы раз сталкивался с необходимостью хранить связанные данные, где важна не только сама информация, но и их взаимосвязь. В дебрях Python словари — это тот универсальный инструмент, который. . .
Реализация паттерна CQRS с Event Sourcing в PHP
Jason-Webb 19.03.2025
CQRS (Command Query Responsibility Segregation) — это архитектурный паттерн, который разделяет операции чтения и записи данных в приложении. Если вы столкнулись с ситуацией, когда ваше PHP-приложение. . .
std::span в C++: Подпредставлени­я и срезы
NullReferenced 18.03.2025
Если вы когда-нибудь работали с большими объемами данных в C++, то наверняка сталкивались с необходимостью манипулировать отдельными частями массивов или контейнеров. Традиционные подходы часто. . .
std::span в C++: Доступ к элементам и итерирование
NullReferenced 18.03.2025
В C++ каждый разработчик сталкивается с проблемой эффективного управления последовательностями данных. Представьте: вы работаете с массивом, передаете его в функцию, а затем в другую, и каждый раз. . .
Утечки памяти в C#
UnmanagedCoder 18.03.2025
Когда мы говорим о разработке приложений на C#, то часто успокаиваем себя мыслью, что сборщик мусора решит все наши проблемы с памятью. "Память управляется автоматически" — эта мантра прочно засела в. . .
std::span в C++: Введение в невладеющее представление
NullReferenced 18.03.2025
С появлением стандарта C++20 у нас появился новый инструмент — std::span, который представляет собой невладеющее представление для работы с последовательностями данных. std::span — это легковесный. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер