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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> набор дат 
:(
    Опции темы
Petro123
Дата 12.10.2007, 15:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



есть две даты d1, d2
Необходимо сформировать набор данных
d1
d1+1
d1+2
...
d2
Такой же вопрос для двух чисел
PM MAIL   Вверх
Filatov NA
  Дата 12.10.2007, 17:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 11
Регистрация: 12.10.2007
Где: г. Нижнекамск

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



Можно так:

Код

create type my_record_type of record
(value);  --  Создается тип записи


create type my_table_type of table as my_record_type;


procedure my_test
(d1  in Date,
 d2  in Date)
return my_table_type pipelend -- Возвращаем данные в виде таблицы

is
  i number;--  Вспомогательная переменная
  c_data  my_record_type; -- Переменная типа "Запись"(Record)

begin

 i:= 0;
 loop -- Начало цикла формирования данных
  c_data.value:= d1+i; --  Присвоение полю переменной значения
  i:= i+1; -- Инкремент
  when d1+i > d2 then exit;  -- Условие выхода

 end loop;  --  Конец цикла
 
 pipe row( c_data );  -- Формирование результирующих строк

 Return; -- Возвращаем результат

end;
 
 

Запрос выглядет следующим образом:

Код

select value from table(my_test(Дата1, Дата2));
 
 

Вот и все!
Если что-то не получится, пишите. Буду рад помочь.
PM MAIL ICQ   Вверх
Petro123
Дата 15.10.2007, 06:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Это все поняно, так действительно можно,
Я подозреваю что сформировать такой набор данных можно всего одним запросом...
PM MAIL   Вверх
Filatov NA
Дата 15.10.2007, 09:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 11
Регистрация: 12.10.2007
Где: г. Нижнекамск

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



Цитата(Petro123 @  15.10.2007,  04:59 Найти цитируемый пост)
Я подозреваю что сформировать такой набор данных можно всего одним запросом... 


А зачем так напрягаться?

Ну поломаешь голову неделю, другую.  Ну найдешь решение. А объем кода, уверен на 90%, будет ни сколько не меньше.
А как результат потраченое в пустую время и злой начальник... smile 

Плюсы:
   быстро;
   качественно;
   удобно для клиента;
   один раз написал - много раз используешь.

По-моемому, плюсов больше. smile 

Это сообщение отредактировал(а) Filatov NA - 15.10.2007, 09:53
PM MAIL ICQ   Вверх
Petro123
Дата 15.10.2007, 12:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Согласен, если приспичило, то подойдет и твое решение, кстати спасибо.
Просто возник чисто спортивный интерес...
PM MAIL   Вверх
LSD
Дата 15.10.2007, 17:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

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



Цитата(Petro123 @  15.10.2007,  07:59 Найти цитируемый пост)
Я подозреваю что сформировать такой набор данных можно всего одним запросом... 

Можно, при условии что у тебя есть запрос, который содержит количество строк, равное или большее, чем количество дат.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
batigoal
Дата 16.10.2007, 17:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Нелетучий Мыш
****


Профиль
Группа: Участник Клуба
Сообщений: 6423
Регистрация: 28.12.2004
Где: Санктъ-Петербургъ

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



all_objects...


--------------------
"Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли)
ЖоржЖЖ
PM WWW   Вверх
Petro123
Дата 18.10.2007, 14:16 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Цитата

Можно, при условии что у тебя есть запрос, который содержит количество строк, равное или большее, чем количество дат. 

Точно!
Кстати прямо в Sql можно ли использовать циклы, если да то в принципе проблема решена,
(ведь условные переходы в sql есть: decode, nvl, case... значит по идее должны быть и циклы)
Или что то, что тиражирует строку n раз
PM MAIL   Вверх
batigoal
Дата 18.10.2007, 15:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Нелетучий Мыш
****


Профиль
Группа: Участник Клуба
Сообщений: 6423
Регистрация: 28.12.2004
Где: Санктъ-Петербургъ

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



В чистом SQL вроде нету. Только в его процедурных диалектах.


--------------------
"Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли)
ЖоржЖЖ
PM WWW   Вверх
LSD
Дата 18.10.2007, 15:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

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



Цитата(Petro123 @  18.10.2007,  15:16 Найти цитируемый пост)
Кстати прямо в Sql можно ли использовать циклы, если да то в принципе проблема решена,

В чистом SQL циклов нет и не может быть, это уже императивные штучки. А SQL функциональный язык.

Цитата(Petro123 @  18.10.2007,  15:16 Найти цитируемый пост)
(ведь условные переходы в sql есть: decode, nvl, case... значит по идее должны быть и циклы)

Это не условные переходы, это функции, которые в зависимости от аргумента возвращают один из результатов.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
DimW
Дата 22.10.2007, 08:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


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

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



Цитата(Petro123 @  18.10.2007,  14:16 Найти цитируемый пост)
Кстати прямо в Sql можно ли использовать циклы, если да то в принципе проблема решена

в явном виде нет, но перебор строк таблицы чем не цыкл: 
Код

select sysdate + rownum from sys.all_objects


вернее так(не вник в суть задачи сразу):
Код

select sysdate/*это - d1*/ + rownum
from sys.all_objects t
where rownum <= (sysdate + 100)/*это - d2*/ - sysdate/*это - d1*/


но все же остается ограничение о котором говорил выше LSD.

Это сообщение отредактировал(а) DimW - 22.10.2007, 16:17
PM MAIL ICQ   Вверх
Petro123
Дата 26.10.2007, 14:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


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

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



Может
Цитата

select sysdate/*это - d1*/ + rownum
from sys.all_objects t
where rownum <= (100)/*это - d2*/ - sysdate/*это - d1*/


Добавлено @ 14:42
То есть вы предлагаете дергать данные из любой таблицы и применять к ним sysdate +  rownum
В принципе вариант, если строк больше чем n

Добавлено @ 14:42
Спасибо, про Rownum чето не догнал

Это сообщение отредактировал(а) Petro123 - 26.10.2007, 14:43
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "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.0790 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


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

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