往其他用户写入select出来的数据别忘记grant授权

往其他用户写入数据别忘记授权:
事件,应用提出需求要往其他用户写数据,由于在同一个库,没必要启用DBLINK,而直接在表名前面加上要插入用户的用户名。
   Insert Into TMP_ADC_ENTRY_CONTAINER (DATA_IMPORT_TIME, ENTRY_ID, CONTAINER_ID)
       Select to_char(end_time, 'yyyymmddHH24mi'), ENTRY_ID, CONTAINER_ID From ADC_ENTRY_CONTAINER;

却一直报Error: PL/SQL: ORA-01031: insufficient privileges错误
Compilation errors for PROCEDURE ADC.PROC_EXPORT_CONTAINERS

Error: PL/SQL: ORA-01031: insufficient privileges
Line: 151


而单独测试
   Insert Into TMP_ADC_ENTRY_CONTAINER (DATA_IMPORT_TIME, ENTRY_ID, CONTAINER_ID) values(sysdate,'1','2')却正常,
百思不得其解,最后想象是否是访问远程表的权限有问题,尝试如下授权:

sys用户下grant select,insert on EPORT.TMP_ADC_ENTRY_CONTAINER to ADC;

授权后执行改语句成功

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值