说说我的想法,你看看行不行:
授权的语句不用说了,你肯定在用着。
关于A中的表生成有规律,是不是可以理解为表名都是一组固定的字符(如你举的例子中,就是T)加上一个序列号(比如用年份加月份)。如果是这样,你可以做一个定时的JOB,每月1日的零点以后执行,JOB里调用一个存储过程,参数是当前的年份月份,如201211,在存储过程中拼接一个授权的SQL,如lstmt := 'GRANT SELECT ON A.T'||||' TO B;',然后执行这个语句。
create or replace procedure test_grant(avc_xh in varchar2)
is
lvc_stmt varchar2(100);
begin
lvc_stmt := 'grant select on A.T' || avc_xh || ' to B;';
execute immediate lvc_stmt;
end;
创建JOB:(以2012年12月开始为例)
DECLARE
l_job NUMBER;
BEGIN
sys.dbms_job.submit
(l_job,'test_grant(to_char(sysdate,'yyyymm'));',to_date('20121201 01:00:00','yyyymmdd hh:mi:ss'),'add_months(trunc(sysdate),1)+1/24',false);
commit;
END;
/
取消
评论