oracle dblink 20001,解决ORA-02021: 不允许对远程数据库进行 DDL 操作下面通过DBLINK调用远程过程来执行这样的操作。...
一般情况下,当我们直接truncate一个远程的表的时候,通常会返回如下的错误信息:
ORA-02021: DDL operations are not allowed on a
remote database.
比如下面的示例:
先在数据库test上创建一个test表,并插入一些数据,如下:
SQL> conn toms/toms
已连接。
SQL> select instance_name from v$instance;
INSTANCE_NAME
----------------
test
SQL> create table test(no int);
表汛唇ā?
SQL> insert into test values(100);
已创建 1 行。
SQL> commit;
提交完成
然后在另外一个数据库(study)上建一个 dblink,并尝试去truncate test数据库上
toms用户下的test表:
SQL> select instance_name from v$instance;
INSTANCE_NAME
----------------
study
SQL> create database link from_test connect to toms
identified by toms using 'local_test';
数据库链接已创建。
SQL> select * from toms.test@from_test;
未选定行
SQL> truncate table toms.test@from_test;
truncate table toms.test@from_test
*
ERROR 位于第 1 行:
ORA-02021: 不允许对远程数据库进行 DDL 操作
SQL>
这时,我们得到了ORA-02021这样的错误,Oracle不允许这么做。那么如果确实有这样的需求,
我们该怎么办呢。下面我介绍一个方法:
先在test数据库上,建立一个类似如下的procedure:
SQL> create or replace procedure proc_truncate_remote_tab(p_tname in varchar2) as
2 BEGIN
3 EXECUTE IMMEDIATE 'TRUNCATE TABLE ' || p_tname;
4 EXCEPTION
5 WHEN OTHERS THEN
6 raise_application_error(-20001,SQLERRM);
7 end;
8 /
过程已创建。
然后在study数据库上调用test数据库上的这个procedure去完成这个truncate动作:
BEGIN proc_truncate_remote_tab@db_link('remote_table_name'); END;
下面测试验证一下:
SQL> select instance_name from v$instance;
INSTANCE_NAME
----------------
study
SQL>
SQL> select *from test@from_test;
NO
----------
100
SQL> begin
2 proc_truncate_remote_tab@from_test('test');
3 end;
4 /
PL/SQL 过程已成功完成。
SQL> select *from test@from_test;
未选定行
SQL>
可以看到,远程test数据库上toms用户下的表test已经被truncate掉了。
注释:
在远程的库建立一个存储过程,这个存储过程声明为自治事务,它接受一个参数,可以是你要建立的表名。
过程里面采用动态SQL建表。
然后你就可以远程调用这个过程。
但不知道这样做有什么实用意义。
上述用在远程的库建立一个存储过程的方法,不能解决“将访问本地数据库上一个方案里的表的权限授权给远程数据库上的一个用户”(即如 grant select on tab to user@dblink(或是global name) )的问题.
oracle dblink 20001,解决ORA-02021: 不允许对远程数据库进行 DDL 操作下面通过DBLINK调用远程过程来执行这样的操作。...相关推荐
- oracle sqlnet配置,sqlnet.ora文件配置详解
一.于sqlnet.ora的说明: *****************************************************FROM ORACLE11G DOCS********** ...
- oracle错误号提示ORA-
网络收集 ORA-00001: 违反唯一约束条件 (.) ORA-00017: 请求会话以设置跟踪事件 ORA-00018: 超出最大会话数 ORA-00019: 超出最大会话许可数 ORA-0002 ...
- 如何通过dblink truncate远程数据库上的表
一般情况下,当我们直接truncate一个远程的表的时候,通常会返回如下的错误信息: ORA-02021: DDL operations are not allowed on a remote dat ...
- Oracle变异表解决方法--ORA-04091错误
Oracle变异表解决方法--ORA-04091错误 原因:触发器(或者被语句中引用的用户自定义PL/SQL函数)视图去查询(或修改)一个被另一语句修改而触发的表. 解决方法:重写触发器(或函数)避免 ...
- Linux x86主机运行天数是是24.8的倍数都有可能引发oracle bug及解决方法
问题是因后台无法登录发现该BUG的,连PLSQL及服务器上的oracle DBA也无法登录oracle 查看系统相关资源: 负载高,系统层的CPU使用高, 解决方法: 重启服务器,问题解决 通过查找原 ...
- oracle in查询 一直等待,学习笔记:Oracle awr 分析解决inactive transaction branch等待事件...
天萃荷净 通过Oracle AWR报告分析inactive transaction branch等待事件的原因 分析一份awr,发现不太熟悉的等待事件"inactive transactio ...
- windows平台下的oracle ORA-01031的解决方法
windows平台下的oracle ORA-01031的解决方法 今天下午遇到一个很怪异的问题,在windows平台下sqlplus / as sysdba登陆数据库,提示权限不足, 当时就纳闷了,s ...
- Oracle DBlink创建访问远程数据库
一.使用场景 当要夸服务器访问数据库时,我们可以使用dblink建立连接服务器间的通道,本地创建了远程数据库的dblink后,访问远程服务器的库就像操作一个库一样了. 二.查看已创建的DBlink S ...
- oracle-12514,Oracle错误 ORA-12514 解决方法
成功连到数据库上之后,查看listener状态:lsnrctl status status READY 状态,需要由非归档转为归档模式,故操作如下: 1.关闭 Oracle错误 ORA-12514 解 ...
最新文章
- 解除微信回调的Activity必须在包名.wxapi下的限制
- 漫话:如何给女朋友解释什么是单例模式?
- 什么叫做“假学习”?什么叫做“真学习”?
- XML——使用 XPath来定位信息+使用命名空间
- 58到家为2000万家庭提供上门生活服务的背后是云计算的高效支撑
- java php 女生数量,萌妹子告诉你php和java如何选
- java(18) - 枚举类型和静态导入
- 如何删除浏览器7654导航首页
- 如何自定义Steam搜索设置
- Mybatis 报错Mapper method ‘xxx‘ has an unsupported return type
- SQL查询语句可以执行,但是提示对象名无效
- 《杜拉拉升职记》——值得一读的一本好书
- Spring Destroying singletons ... root of factory hierarchy 问题【已解决】
- vbs查看系统开关机时间
- 【智能商务】海量商品查找利器—苏宁搜索系统
- 修复液晶显示器屏幕上的划痕
- 2021-10-27 基于电影数据库的简单查询(数据库第二次实验)
- 2021年开源SLAM算法
- 罗克韦尔自动化和PTC为由PTC支持的FactoryTalk InnovationSuite™添加行业首创的增强功能,用于简化和加速数字化转型
- 二叉树——二叉树的深度