#oracle #plsql
#Oracle #plsql
Вопрос:
У меня есть вопрос, связанный с моим триггером ddl:
create or replace trigger audit_ddl_db_trg after ddl on database
begin
DECLARE
n number;
stmt varchar2(4000);
sql_text ora_name_list_t;
begin
dbms_output.put_line(ora_sql_txt(sql_text));
n := ora_sql_txt(sql_text);
IF nvl(n,200)=200 THEN
Raise_application_error(-20001, 'ora_sql_txt does not catch any statement. sql_txt is not initialized');
ELSE FOR i IN 1..n LOOP
stmt := stmt || sql_text(i);
END LOOP;
dbms_output.put_line(stmt);
END IF;
IF ora_sysevent <> 'TRUNCATE'
THEN
if (ora_sysevent='TRUNCATE')
then
null; -- I do not care about truncate
else
insert into audit_ddl(date_of_change,osuser,current_user,host,terminal,owner,object_type,object_name,ora_sysevent,sqltext)
values(
systimestamp,
sys_context('USERENV','OS_USER') ,
sys_context('USERENV','CURRENT_USER') ,
sys_context('USERENV','HOST') ,
sys_context('USERENV','TERMINAL') ,
ora_dict_obj_owner,
ora_dict_obj_type,
ora_dict_obj_name,
ora_sysevent,
stmt
);
end if;
end if;
end;
end;
Триггер улавливает все правильно, в моей таблице все заполнено правильно, но у меня есть вопросы, связанные с столбцом current_user. Независимо от того, какую пользовательскую схему я использую в базе данных для изменения, она записывает SYS. Как заполнить это правильным пользователем, который выполнил изменение в таблице?
Спасибо!
Ответ №1:
sys_context('USERENV','CURRENT_USER')
возвращает имя пользователя базы данных, чьи привилегии в данный момент активны, согласно документации oracle.
Вы можете использовать SESSION_USER
вместо CURRENT_USER
.