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

真题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;

例如:

[email protected] > 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

[email protected] > DROP TABLE LHR.SYS_EXPORT_SCHEMA_04 PURGE;

Table dropped.

[email protected] >  SELECT * FROM DBA_DATAPUMP_SESSIONS;

no rows selected

[email protected] > 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;

原文地址:http://blog.51cto.com/lhrbest/2104072

时间: 2024-10-29 03:33:43

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

Oracle中使用游标获取指定数据表的所有字段名对应的字符串

操作步骤:打开PLSQL Developer后,直接执行下面的语句就可以出来 --Oracle中使用游标获取指定数据表的所有字段名对应的字符串 declare mytablename VARCHAR(255):='STAFFDOC'; --定义要查询的数据表名变量,STAFFDOC为我测试用的数据表名,请修改成您的数据库中的对应数据表名字mystring NVARCHAR2(4000):=''; --定义要输出的字符串变量 cursor mycursor is --定义游标          s

oracle中导出导入表以及数据

Oracle数据导入导出imp/exp就相当于oracle数据还原与备份.exp命令可以把数据从远程数据库服务器导出到本地的dmp文件,imp命令可以把dmp文件从本地导入到远处的数据库服务器中.利用这个功能可以构建两个相同的数据库,一个用来测试,一个用来正式使用.执行环境:可以在SQLPLUS.EXE或者DOS(命令行)中执行,DOS中可以执行时由于 在oracle 8i 中安装目录\ora81\BIN被设置为全局路径,该目录下有EXP.EXE与IMP.EXE文件被用来执行导入导出.oracl

oracle中取前几条数据&TRUNC()函数

在oracle中查表中的前10条数据---- select * from test where rownum <= 10 ;  rownum是把SQL出来的结果进行编号,始终从1开始,常见的用途就是用来分页.类似于MYSQL和SQL SERVER的top. select * from (select a.*,rownum rn from test a) where rn >=10 and rn<=20; 输出10到20条语句.因为rownum本身只能用<=的比较方式,只有转成实例才

oracle中查询含字母的数据[正则表达式]

1,REGEXP_LIKE :与LIKE的功能相似2,REGEXP_INSTR :与INSTR的功能相似3,REGEXP_SUBSTR :与SUBSTR的功能相似4,REGEXP_REPLACE :与REPLACE的功能相似它们在用法上与Oracle SQL 函数LIKE.INSTR.SUBSTR 和REPLACE 用法相同,但是它们使用POSIX 正则表达式代替了老的百分号(%)和通配符(_)字符.POSIX 正则表达式由标准的元字符(metacharacters)所构成:'^' 匹配输入字符

修改Oracle中的某一带有数据的列的数据类型

因为昨天去别的公司维护数据,到了之后导完数据才发现,表中的要素内容这一列是空的,刚开始我以为是数据有问题,后来才发现表中的数据的类型是CLOB类型的,而如果直接拿EXCLE中的数据是类型不匹配的,这时候就问了领导,领导说把CLOB类型改成varchar2类型的,不多说了上步骤: 因为该列中已经存有数据,所以需要如下: *修改原字段名*/ALTER TABLE 表名 RENAME COLUMN 字段名 TO 字段名1;/*添加一个和原字段同名的字段*/ALTER TABLE 表名 ADD 字段名 

查询Oracle中字段名带&quot;.&quot;的数据

SDE中的TT_L线层会有SHAPE.LEN这样的字段,使用: SQL>select shape.len from tt_l; 或 SQL>select t.shape.len from tt_l t; 是查询不出来的. 需要这样查询: SQL>select t."SHAPE"."LEN" from tt_l t;

恢复oracle中update或delete的数据

问题描述 比如在开发人员对employee表进行一个update语句,但更新完之后,才发现更新的语句有误,需要撤销刚才的update操作.如(update employee e set e.block='0300100011000000248' wheree.block='0300100011000000240'; 更新了10条数据) 1.如果在很短的时间内,可以查询数据库中的versions,记录短时间内的employee表中的update.delete.insert的操作.(时间多长取决于数

oracle中lock和latch的用途

本文向各位阐述Oracle的Latch机制,Latch,用金山词霸翻译是门插栓,闭锁,专业术语叫锁存器,我开始接触时就不大明白为什么不写Lock,不都是锁吗?只是翻译不同而以?研究过后才知道两者有很大的区别. Oracle中锁的信息是数据块的一部分,是物理的,并不是逻辑上属于某个表或者某个行.Latch是Oracle提供的轻量级锁资源,他用于快速,短时间的锁定资源,防止多个并发进程同时修改访问某个共享资源,他只工作在内存中, 我们可以不大准确的说,内存中资源的锁叫latch,数据库对象(表,索引

Oracle 数据泵文件

数据泵文件 expdp介绍 EXPDP命令行选项1. ATTACH该选项用于在客户会话与已存在导出作用之间建立关联.语法如下ATTACH=[schema_name.]job_nameSchema_name用于指定方案名,job_name用于指定导出作业名.注意,如果使用ATTACH选项,在命令行除了连接字符串和ATTACH选项外,不能指定任何其他选项,示例如下:Expdp scott/tiger ATTACH=scott.export_job 2. CONTENT该选项用于指定要导出的内容.默认