Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Oracle sequences

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
UVV
Гость





СообщениеДобавлено: Вт Янв 04 2005 18:38    Заголовок сообщения: Oracle sequences Ответить с цитатой

Подскажите, как пересоздать (сбросить) последовательность в Oracle каждый
Новый Год?
Вернуться к началу
gkb
Гость





СообщениеДобавлено: Пт Янв 28 2005 20:19    Заголовок сообщения: Ответить с цитатой

drop sequence ...
create sequence ...
Вернуться к началу
drmorgue



Зарегистрирован: 10.02.2005
Сообщения: 5

СообщениеДобавлено: Чт Фев 10 2005 17:07    Заголовок сообщения: Ответить с цитатой

Идея - создаём джоб, который будет запускаться раз в год. Джоб будет запускать хранимую процедуру, которая средствами динамического SQL-а будет пересоздавать Вашу последовательность.

Процедура:
Код:

create procedure my_job_proc
as
  c_id number;
begin
  c_id := dbms_sql.open_cursor;
  dbms_sql.parse(cur_id, 'create sequence my_s start with 1',
      dbms_sql.v7);
  ret_val := dbms_sql.execute(cur_id);
  dbms_sql.close_cursor(cur_id);
end;


Джоб:
Код:
declare
  n_job number;
begin
  dbms_job.submit(n_job, 'my_job_proc;', sysdate, 'sysdate+365');
  dbms_output.put_line('job id: ' || n_job);
end;
/


PS: Может, есть какие синтаксические ошибки в коде - писал сразу, без проверок, но идея, думаю, будет ясна
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
drmorgue



Зарегистрирован: 10.02.2005
Сообщения: 5

СообщениеДобавлено: Чт Фев 10 2005 17:09    Заголовок сообщения: Ответить с цитатой

ааа, забыл...
сначала надо сделать тем же динамическим SQL-ом 'drop sequence my_s' внутри процедуры my_job_proc, а потом только 'create sequence...'
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
gkb



Зарегистрирован: 03.02.2005
Сообщения: 4

СообщениеДобавлено: Чт Фев 10 2005 19:25    Заголовок сообщения: Ответить с цитатой

и если oracle 9-й и старше вместо dbms_sql проще пользоваться execute immediate '<команда>'
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...