Гость
Форумы / Oracle [игнор отключен] [закрыт для гостей] / Процедура / функция / 5 сообщений из 5, страница 1 из 1
07.06.2021, 23:20
    #40076256
nachPro___23-3
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Процедура / функция
Нужна процедура которая переливает данные с одной таблицы в другую, при этом перед заливкой удалять партиции.
в чем ошибка ?

create or replace procedure refresh_tablename
is
v_report_period number;
begin

select to_char((sysdate-1), 'YYYYMM')
into v_report_period_id
from dual;



execute immediate 'alter table schema.table1 truncate partition P' ||v_report_period_id;


insert into schema.table1
(
report_period_id,
column 1
column 2
column 3
column 4
column 5
column 6
column 7
column 8
column 9
column 10
column 11
column 12
column 13
column 14
column 15
date_to
dn_date
)

select distinct v_report_period_id as report_period_id,
column 1
column 2
column 3
column 4
column 5
column 6
column 7
column 8
column 9
column 10
column 11
column 12
column 13
column 14
column 15
date_to
dn_date

from schema2.table2
commit;
end;
...
Рейтинг: 0 / 0
08.06.2021, 02:49
    #40076267
SY
SY
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Процедура / функция
И что тут неясно?

Код: plsql
1.
2.
3.
4.
5.
6.
v_report_period number; -- и где тут _id
begin

select to_char((sysdate-1), 'YYYYMM')
into v_report_period_id
from dual;



Ну а теперь выкинь этот кусок и просто выполни:

Код: plsql
1.
execute immediate 'alter table schema.table1 truncate partition P' || to_char(sysdate - 1,'YYYYMM');



SY.
...
Рейтинг: 0 / 0
08.06.2021, 08:05
    #40076278
nachPro___23-3
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Процедура / функция
SY,

execute immediate 'alter table schema.table1 truncate partition P' || to_char(sysdate - 1,'YYYYMM'); - почему to_char(sysdate...) если мне транкейт поле надо партиции ?


execute immediate 'alter table schema.table1 truncate partition P' ||v_report_period_id;

Но выдает ошибку: ORA01735
...
Рейтинг: 0 / 0
08.06.2021, 10:28
    #40076298
nachPro___23-3
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Процедура / функция
Можно закрывать
...
Рейтинг: 0 / 0
08.06.2021, 12:12
    #40076334
andrey_anonymous
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Процедура / функция
nachPro___23-3
в чем ошибка ?

Концептуально ошибочна автоматизация обрезки по имени .
Откройте для себя
Код: plsql
1.
partition for()
...
Рейтинг: 0 / 0
Форумы / Oracle [игнор отключен] [закрыт для гостей] / Процедура / функция / 5 сообщений из 5, страница 1 из 1
Целевая тема:
Создать новую тему:
Автор:
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]