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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Можна ли в переменую засунуть запрос? 
:(
    Опции темы
kentaro
Дата 6.11.2009, 14:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



Помогите сделать запрос я хочу чтоб при приходе параметра выполнялся определёный запрос,чтоб его занова не писать.Например t=select * from и.т.д затем from( t).Просто запрос находится в цикле а там нельзя поставить условия что переменая равна=y сделать и написать другой селект?
PM MAIL   Вверх
cra6
Дата 6.11.2009, 14:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



select * from (select * from table)  это обычный подзапрос
То что ты хочеш это динамический sql. 
http://www.oracle.com/global/ru/oramag/dec...querty_din.html
Но мне кажется тебе это не нужно.Опиши задачу получше
PM MAIL   Вверх
DimW
Дата 6.11.2009, 14:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


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

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



Цитата(cra6 @  6.11.2009,  14:32 Найти цитируемый пост)
это обычный подзапрос 

да не, судя по "t=select * from" ТС хочет рузультат запроса хранить в переменной, а потом из этой переменной получать результат несколько раз.

Цитата(kentaro @  6.11.2009,  14:07 Найти цитируемый пост)
Просто запрос находится в цикле а там нельзя поставить условия что переменая равна=y сделать и написать другой селект? 

покажите кусок кода где "запрос в цикле".

kentaro, лучше обьясните что вам нужно, а не что делать с тем что вы уже наделали.


Это сообщение отредактировал(а) DimW - 6.11.2009, 14:56
PM MAIL ICQ   Вверх
kentaro
Дата 9.11.2009, 09:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


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

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



DimW
Код

 for rec in ( select t.filial filial_code,
       (select f.code_bank from filial_desc f where f.code = t.filial) filial_mfo,
       (select f.name from filial_desc f where f.code = t.filial)  filial_name,
       sum(((t.sumpay/100)*t.comm)/100) summa_comm,
       sum (t.sumpay/100) summa_all
        
  from(  
      
        select * from reestrs t 
         where t.state = 'B'
           and t.operday between vDateBegin
                             and vDateEnd 
           and t.filial = NVL(NULL,iFilial) 
         union
        select * from reestrs_old t 
         where t.state = 'B'
           and t.operday between vDateBegin
                             and vDateEnd 
           and t.filial = NVL(NULL,iFilial)
       )t



Добавлено через 8 минут и 20 секунд
Мне нужна отчет по филиалам.В одном случае так  
Код

and t.filial = NVL(NULL,iFilial) 
а когда параметер приходит то так 
Код

and t.filial = NVL(NULL,t.Filial)


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


Эксперт
***


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

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



Цитата(kentaro @  9.11.2009,  09:48 Найти цитируемый пост)
В одном случае так  

я правильно понимаю что если параметр is not null то ищем по нему, если is null то берем все филиалы?

если так то:
Код

and (iFilial is null or t.Filial = iFilial) -- если параметр is null то ограничений по филиалам нет


к чему был вопрос про:
Цитата(kentaro @  6.11.2009,  14:07 Найти цитируемый пост)
Например t=select * from

я так и не понял.

PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Oracle"
Zloxa
LSD

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

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

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

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

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


 




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


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

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