dbms_utility.exec_ddl_statement 不起作用

Posted

技术标签:

【中文标题】dbms_utility.exec_ddl_statement 不起作用【英文标题】:dbms_utility.exec_ddl_statement doesn't work 【发布时间】:2019-11-23 08:33:32 【问题描述】:

我想通过 dblink 终止会话,但是 。

以下命令不会引发任何错误,但也不会终止会话。

exec dbms_utility.exec_ddl_statement@dblink('Alter system kill session ''274,12303,@1'' immediate'); 

【问题讨论】:

【参考方案1】:

您似乎想终止驻留在远程数据库中的会话。如果是这样的话,

在该(远程)数据库中创建一个过程 它会终止会话 一种选择是使用动态 SQL 来执行此操作(即execute immediate) 哪一个?参数将作为过程参数传递的那个 通过数据库链接调用过程

【讨论】:

我知道替代方法。问题就是这样产生的。它应该可以工作,但事实并非如此。【参考方案2】:

我假设节点=1 上 sid=274, serial=12303 的会话正在运行繁重的 DML/DDL 语句,并且说“它不会终止会话”意味着会话被视为活动的命令运行后在 GV$SESSION 中。

这是预期的行为。尽管可能违反直觉,但 KILL SESSION 并没有真正“杀死”会话 - 它会发送一个终止信号,会话将在当前工作完成后尊重该信号。不是以前。所以不是假设场景的选择。

另外两个选项:

ALTER SYSTEM DISCONNECT SESSION '274,12303,@1' IMMEDIATE 杀死操作系统进程。

ORACLE-BASE article

附: dbms_utility.exec_ddl_statement@dblink(q'!Alter system kill session '274,12303,@1' immediate!');alternative quoting mechanism。自 10 克以来不再出现双标。

【讨论】:

不,它只是在 sqlplus 上创建的虚拟会话。还是不杀。并尝试使用 q'!但它也没有用。

以上是关于dbms_utility.exec_ddl_statement 不起作用的主要内容,如果未能解决你的问题,请参考以下文章