EXP的QUERY参数

QUERY
默认:none
当导出模式为表模式时,此参数可以选择这些表中的子集。query参数的相当于在select语句中增加了where条件。此条件应用于tables参数中的所有表。需要注意的是,query参数必须适合所有表,比如有某张表无where中的列,那就会报错。
query参数限制:
1 不能用在full,user,表空间导出模式。
 2 参数应用于所有表,不能特别指定某张表。
3 direct path export不能使用query参数。因为direct path export没有通过sql应用层,不会使用where条件去应用query参数。
4 不能应用于嵌套表。
5 不能确定结果集是否是query的结果集

我们来做个实验来进一步认识上面的解释
[oracle@lzl ~]$ vi parfile_lzl.txt 
[oracle@lzl ~]$ cat parfile_lzl.txt 
userid=scott/tiger
file=/home/oracle/exp_lzl.dmp
log=/home/oracle/exp_lzl.log
tables=emp
buffer=1024
query="where rownum<=1
[oracle@lzl ~]$ cat exp_lzl.log 
Connected to: Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
Export done in ZHS16GBK character set and AL16UTF16 NCHAR character set
About to export specified tables via Conventional Path ...
. . exporting table                            EMP          1 rows exported
EXP-00091: Exporting questionable statistics.
EXP-00091: Exporting questionable statistics.
Export terminated successfully with warnings.
从日志来看,只可以看到行数。这样就必须要先查询导出表的行数,是否行数于导出行数一致才可以判断是否使用了query参数。在看dmp文件,因为dmp是二进制文件,所以要使用strings命令
[oracle@lzl ~]$ strings exp_lzl.dmp 
TEXPORT:V11.02.00
DSCOTT
RTABLES
8192
                                       Sun Jul 9 10:16:13 2017/home/oracle/exp_lzl.dmp
#G#G
#G#G
+00:00
BYTE
UNUSED
INTERPRETED
DISABLE:ALL
METRICST
TABLE "EMP"
CREATE TABLE "EMP" ("EMPNO" NUMBER(4, 0), "ENAME" VARCHAR2(10), "JOB" VARCHAR2(9), "MGR" NUMBER(4, 0), "HIREDATE" DATE, "SAL" NUMBER(7, 2), "COMM" NUMBER(7, 2), "DEPTNO" NUMBER(2, 0))  PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT) TABLESPACE "USERS" LOGGING NOCOMPRESS

ANALCOMPUTE TR "EMP" ANALYZE  TABLE "EMP"  ESTIMATE STATISTICS 
ENDTABLE
METRICET 3
METRICSTEnable enforce constraints 
TABLE "EMP"
ALTER TABLE "EMP" ENABLE CONSTRAINT "FK_DEPTNO"
ENDTABLE
METRICET 4
METRICETG0
EXIT
EXIT
dmp文件其实显示的是表的创建语句及其索引,约束,统计信息的统计信息等等。所以使用了query参数后最好有记录,不然难以找到where子句到底写了什么。使用参数文件就是一个很好的记录方法。



来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31461640/viewspace-2141779/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/31461640/viewspace-2141779/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值