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

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

22.09.2009, 17:21. Показов 4299. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Циклы for в Python
py-thonny 17.03.2025
Существует множество ситуаций, когда нам нужно выполнить одно и то же действие несколько раз. Цикл for в Python — настоящий рабочий конь для большинства программистов. Если вам нужно пройтись по всем. . .
Предсказание ветвлений - путь к высокопроизводи­тельному C++
NullReferenced 17.03.2025
В высокопроизводительном программировании на C++ каждый такт процессора на счету. Когда речь заходит о разработке систем с низкой задержкой — будь то высокочастотная торговля, обработка потоковых. . .
Паттерн CQRS в C#
UnmanagedCoder 17.03.2025
Создание сложных корпоративных приложений часто требует нестандартных подходов к архитектуре. Один из таких подходов — паттерн CQRS (Command Query Responsibility Segregation), предлагающий простую,. . .
Паттерн Цепочка ответственности в C#
UnmanagedCoder 17.03.2025
Цепочка ответственности — это поведенческий паттерн проектирования, который позволяет передавать запросы последовательно по цепочке потенциальных обработчиков, пока один из них не обработает запрос. . . .
Создаем микросервисы с NestJS, TCP и Typescript
run.dev 17.03.2025
NestJS — фреймворк, который значительно упрощает создание серверных приложений на Node. js. Его прелесть в том, что он комбинирует концепции ООП, функционального программирования и предлагает. . .
Гексагональная архитектура со Spring Boot
Javaican 17.03.2025
Если вы когда-нибудь сталкивались с ситуацией, когда внесение простых изменений в базу данных или пользовательский интерфейс заставляло вас переписывать весь код, то вы точно оцените элегантность. . .
Позиционировани­е Kafka Consumer и Seek-операции
Javaican 17.03.2025
Что же такое Consumer Seek в Kafka? По сути, это API-метод, который позволяет программно указать, с какой позиции (offset) Consumer должен начать или продолжить чтение данных из партиции. Без этого. . .
Python NumPy: Лучшие практики и примеры
py-thonny 17.03.2025
NumPy (Numerical Python) — одна из ключевых библиотек для научных вычислений в Python. Она превращает Python из просто удобного языка общего назначения в среду для проведения сложных математических. . .
Java Micronaut в Docker: контейнеризация с Maven и Jib
Javaican 16.03.2025
Когда речь заходит о микросервисной архитектуре на Java, фреймворк Micronaut выделяется среди конкурентов. Он создан с учётом особенностей облачных сред и контейнеров, что делает его идеальным. . .
Управление зависимостями в Java: Сравнение Spring, Guice и Dagger 2
Javaican 16.03.2025
Инъекция зависимостей (Dependency Injection, DI) — один из фундаментальных паттернов проектирования, который радикально меняет подход к созданию гибких и тестируемых Java-приложений. Суть этого. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер