Oracle给用户授权truncatetable的实现方案

1,对其它用户下的表执行trundate table操作

开发说在用dwetl下执行调用shop用户下的表的时候提示没有权限操作,google了查了下,发现oracle账户没法直接赋予对某个表的truncate权限,那要怎么来实现呢?
在shop用户下面,准备测试数据

create table Z_TruncATE_T(ID number); Table created. sql> insert into Z_TruncATE_T select 1 from dual; 1 row created. sql> commit; Commit complete. sql> select * from Z_TruncATE_T; ID ---------- 1 sql>

2,比较粗鲁不安全的做法

通常赋予truncate的常规做法,是直接赋值drop any table给一个用户

grant drop any table to dwetl; Grant succeeded. sql> sql> grant select,insert,delete,update on Z_TruncATE_T to dwetl; Grant succeeded. sql>

干完活,需要赶紧马上收回权限因为drop any table权限是在太大了,一不小心就会造成误删除,到时候哭都来不及啊

revoke drop any table from dwetl; Revoke succeeded. sql> revoke select,update on shop.PLAN6_TEMPLET_NODE_EDIT from dwetl; Revoke succeeded. sql>

3,比较安全的做法

建立一个存储过程p_truncate,在存储过来里面执行truncate table Z_TruncATE_T;然后赋予另外一个用户dwetl对这个存储过程的执行权限。

存储过程p_truncate如下:

rush:sql;"> create or replace procedure p_truncate as begin execute immediate 'truncate table Z_TruncATE_T'; end;

建立存储过程:

create or replace procedure p_truncate as begin execute immediate 'truncate table Z_TruncATE_T'; 4 end; 5 / Procedure created. sql>

赋予存储过程的执行权限给dwetl,并且赋予表的增删改查权限,因为truncate后,紧接着的基本就是insert、update、delete了

grant execute on p_truncate to dwetl; Grant succeeded. sql> sql> grant select,update on Z_TruncATE_T to dwetl; Grant succeeded. sql>

通过dwetl账号登陆,执行存储过程查看效果,看到shop用户下的表Z_TruncATE_T已经被清空了,ok,如此也证明了通过存储过程这种方案是可行的,可以对别的用户下的表进行truncate table操作。
–查看

call shop.p_truncate(); Call completed. sql> select * from shop.Z_TruncATE_T; no rows selected sql>

以上所述是小编给大家介绍的Oracle给用户授权truncatetable的实现方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程之家网站的支持

相关文章

Java Oracle 结果集是Java语言中处理数据库查询结果的一种方...
Java AES和Oracle AES是现代加密技术中最常使用的两种AES加密...
Java是一种广泛应用的编程语言,具备可靠性、安全性、跨平台...
随着移动互联网的发展,抽奖活动成为了营销活动中不可或缺的...
Java和Oracle都是在计算机领域应用非常广泛的技术,他们经常...
Java 是一门非常流行的编程语言,它可以运行于各种操作系统上...