返回顶部
首页 > 资讯 > 数据库 >【DB笔试面试164】在Oracle中,如何彻底停止expdp数据泵进程?
  • 489
分享到

【DB笔试面试164】在Oracle中,如何彻底停止expdp数据泵进程?

2024-04-02 19:04:59 489人浏览 薄情痞子
摘要

真题1、如何彻底停止expdp进程?答案:许多同事在使用expdp命令时,不小心按了CTRL+C组合键,然后又输入exit命令(或者网络中断等异常情况),导致expdp进程不存在,但Oracle数据库的会话

真题1、如何彻底停止expdp进程?


答案:许多同事在使用expdp命令时,不小心按了CTRL+C组合键,然后又输入exit命令(或者网络中断等异常情况),导致expdp进程不存在,但Oracle数据库的会话仍存在,所以dmp文件也一直在增长。在这种情况下的处理办法如下所示:

1、检查expdp进程是否还在

ps -ef | grep expdp

若存在,则可用“kill -9 process”命令杀掉expdp的进程。

2、检查会话是否仍存在,若存在则把相关的会话杀掉(注意:先使用命令“ALTER SYSTEM KILL SESSioN SID,SERIAL# IMMEDIATE;”在数据库级别杀掉会话,然后在OS级别使用kill -9杀掉进程),如无杀会话的权限则可以将相关的表DROP掉,表名可以使用如下的sql来查询:

SELECT * FROM DBA_DATAPUMP_SESSIONS;

SELECT * FROM DBA_DATAPUMP_JOBS;

例如:

SYS@orclasm > SELECT * FROM DBA_DATAPUMP_SESSIONS;

OWNER_NAME JOB_NAME                     INST_ID SADDR            SESSION_TYPE

---------- ------------------------- ---------- ---------------- --------------

LHR        SYS_EXPORT_SCHEMA_04               1 00000000A8B71D98 MASTER

LHR        SYS_EXPORT_SCHEMA_04               1 00000000AB98AFC8 WORKER

SYS@orclasm > DROP TABLE LHR.SYS_EXPORT_SCHEMA_04 PURGE;

Table dropped.

SYS@orclasm >  SELECT * FROM DBA_DATAPUMP_SESSIONS;

no rows selected

SYS@orclasm > SELECT * FROM DBA_DATAPUMP_JOBS;

no rows selected

使用相同的办法也删除从视图DBA_DATAPUMP_JOBS中查询出来的表,直到这两个视图无记录。

3、删除导出的dmp文件。如不删除,则在重新执行expdp命令时会报dmp文件已存在的错误。

这里作者给出自己常用的一个SQL语句,可以查询expdp的相关会话的详细信息,如下所示:

---------------------------如何彻底停止expdp进程?

SET LINE 9999

COL OWNER_NAME FOR A10

COL JOB_NAME FOR A25

COL OPERATION FOR A10

COL JOB_MODE FOR A10

COL STATE FOR A15

COL OSUSER FOR A10

COL "DEGREE|ATTACHED|DATAPUMP" FOR A25

COL SESSION_INFO FOR A20 

SELECT DS.INST_ID,

       DJ.OWNER_NAME,

       DJ.JOB_NAME,

       TRIM(DJ.OPERATION) OPERATION,

       TRIM(DJ.JOB_MODE) JOB_MODE,

       DJ.STATE,

       DJ.DEGREE || ',' || DJ.ATTACHED_SESSIONS || ',' ||DJ.DATAPUMP_SESSIONS "DEGREE|ATTACHED|DATAPUMP",

       DS.SESSION_TYPE,

       S.OSUSER ,

       (SELECT S.SID || ',' || S.SERIAL# || ',' || P.SPID

          FROM GV$PROCESS P

         WHERE S.PADDR = P.ADDR

           AND S.INST_ID = P.INST_ID) SESSION_INFO

  FROM DBA_DATAPUMP_JOBS DJ --GV$DATAPUMP_JOB 

  FULL OUTER JOIN DBA_DATAPUMP_SESSIONS DS --GV$DATAPUMP_SESSION

    ON (DJ.JOB_NAME = DS.JOB_NAME AND DJ.OWNER_NAME = DS.OWNER_NAME)

  LEFT OUTER JOIN GV$SESSION S

    ON (S.SADDR = DS.SADDR AND DS.INST_ID = S.INST_ID)

 ORDER BY DJ.OWNER_NAME, DJ.JOB_NAME;

 

 

 

 

select * from GV$DATAPUMP_SESSION;

select * from GV$datapump_jobs;

select * From dba_datapump_jobs;

 

 

 



您可能感兴趣的文档:

--结束END--

本文标题: 【DB笔试面试164】在Oracle中,如何彻底停止expdp数据泵进程?

本文链接: https://lsjlt.com/news/39075.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作