社区
基础和管理
帖子详情
这事麻烦了,使用EXP导出数据库时出现了如下错误!!在线急问
blackhost
2009-07-10 02:37:30
EXP-00008: 遇到 ORACLE 错误 904
ORA-00904: "MAXSIZE": invalid identifier
请大侠指点迷津啊
...全文
97
9
打赏
收藏
这事麻烦了,使用EXP导出数据库时出现了如下错误!!在线急问
EXP-00008: 遇到 ORACLE 错误 904 ORA-00904: "MAXSIZE": invalid identifier 请大侠指点迷津啊
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
9 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
blackhost
2009-07-10
打赏
举报
回复
问题解决了!是缺少相应的数据字典导致的,
解决方案很简单,只要以sysdba执行
%ORACLE_HOME/rdbms/admin/catexp.sql建立所需要的数据字典即可。
晕死~~~~~~~~~~~~~大家都有分
阿三
2009-07-10
打赏
举报
回复
exp username/password@sid rows=y indexes=n compress=n buffer=65536
feedback=100000 volsize=0
file=exp01.dmp
log=exp01.log
试试
blackhost
2009-07-10
打赏
举报
回复
然后选择的是用户导出,但是我选表导出,也出现同样问题
blackhost
2009-07-10
打赏
举报
回复
exp username/password@sid
阿三
2009-07-10
打赏
举报
回复
把你的exp语句写出来,看看
blackhost
2009-07-10
打赏
举报
回复
根本就没有maxsize这个字段
阿三
2009-07-10
打赏
举报
回复
看看包含maxsize这个字段的表结构是如何定义的
robin_ares
2009-07-10
打赏
举报
回复
MAXSIZE可是关键字
是不是和这个有关系
shiyiwan
2009-07-10
打赏
举报
回复
检查下表里面有MAXSIZE这个字段么?
oracle详解
导入/
导出
是ORACLE幸存的最古老的两个命令行工具,其实我从来不认为
Exp
/Imp是一种好的备份方式,正确的说法是
Exp
/Imp只能是一个好的转储工具,特别是在小型
数据库
的转储,表空间的迁移,表的抽取,检测逻辑和物理冲突等中有不小的功劳。当然,我们也可以把它作为小型
数据库
的物理备份后的一个逻辑辅助备份,也是不错的建议。对于越来越大的
数据库
,特别是TB级
数据库
和越来越多数据仓库的
出现
,
EXP
/IMP越来越力不从心了,这个
时
候,
数据库
的备份都转向了RMAN和第三方工具。下面说明一下
EXP
/IMP的
使用
。 如何使
exp
的帮助以不同的字符集显示:set nls_lang=simplified chinese_china.zhs16gbk,通过设置环境变量,可以让
exp
的帮助以中文显示,如果set nls_lang=American_america.字符集,那么帮助就是英文的了 程序代码
EXP
的所有参数(括号中为参数的默认值): USERID 用户名/口令 如: USERID=duanl/duanl FULL
导出
整个
数据库
(N) BUFFER 数据缓冲区的大小 OWNER 所有者用户名列表,你希望
导出
哪个用户的对象,就用owner=username FILE 输出文件 (
EXP
DAT.DMP) TABLES 表名列表 ,指定
导出
的table名称,如:TABLES=table1,table2 COMPRESS 导入一个extent (Y) RECORDLENGTH IO 记录的长度 GRANTS
导出
权限 (Y) INCTYPE 增量
导出
类型 INDEXES
导出
索引 (Y) RECORD 跟踪增量
导出
(Y) ROWS
导出
数据行 (Y) PARFILE 参数文件名,如果你
exp
的参数很多,可以存成参数文件. CONSTRAINTS
导出
约束 (Y) CONSISTENT 交叉表一致性 LOG 屏幕输出的日志文件 STATISTICS 分析对象 (ESTIMATE) DIRECT 直接路径 (N) TRIGGERS
导出
触发器 (Y) FEEDBACK 显示每 x 行 (0) 的进度 FILESIZE 各转储文件的最大尺寸 QUERY 选定
导出
表子集的子句 下列关键字仅用于可传输的表空间 TRANSPORT_TABLESPACE
导出
可传输的表空间元数据 (N) TABLESPACES 将传输的表空间列表 程序代码IMP的所有参数(括号中为参数的默认值): USERID 用户名/口令 FULL 导入整个文件 (N) BUFFER 数据缓冲区大小 FROMUSER 所有人用户名列表 FILE 输入文件 (
EXP
DAT.DMP) TOUSER 用户名列表 SHOW 只列出文件内容 (N) TABLES 表名列表 IGNORE 忽略创建
错误
(N) RECORDLENGTH IO 记录的长度 GRANTS 导入权限 (Y) INCTYPE 增量导入类型 INDEXES 导入索引 (Y) COMMIT 提交数组插入 (N) ROWS 导入数据行 (Y) PARFILE 参数文件名 LOG 屏幕输出的日志文件 CONSTRAINTS 导入限制 (Y) DESTROY 覆盖表空间数据文件 (N) INDEXFILE 将表/索引信息写入指定的文件 SKIP_UNUSABLE_INDEXES 跳过不可用索引的维护 (N) ANALYZE 执行转储文件中的 ANALYZE 语句 (Y) FEEDBACK 显示每 x 行 (0) 的进度 TOID_NOVALIDATE 跳过指定类型 id 的校验 FILESIZE 各转储文件的最大尺寸 RECALCULATE_STATISTICS 重新计算统计值 (N) 下列关键字仅用于可传输的表空间 TRANSPORT_TABLESPACE 导入可传输的表空间元数据 (N) TABLESPACES 将要传输到
数据库
的表空间 DATAFILES 将要传输到
数据库
的数据文件 TTS_OWNERS 拥有可传输表空间集中数据的用户 关于增量参数的说明:
exp
/imp的增量并不是真正意义上的增量,所以最好不要
使用
。
使用
方法:
Exp
parameter_name=value or
Exp
parameter_name=(value1,value2……) 只要输入参数help=y就可以看到所有帮助.
EXP
常用选项 1.FULL,这个用于
导出
整个
数据库
,在ROWS=N一起
使用
时
,可以
导出
整个
数据库
的结构。例如:
exp
userid=test/test file=./db_str.dmp log=./db_str.log full=y rows=n compress=y direct=y 2. OWNER和TABLE,这两个选项用于定义
EXP
的对象。OWNER定义
导出
指定用户的对象;TABLE指定
EXP
的table名称,例如:
exp
userid=test/test file=./db_str.dmp log=./db_str.log owner=duanl
exp
userid=test/test file=./db_str.dmp log=./db_str.log table=nc_data,fi_arap 3.BUFFER和FEEDBACK,在
导出
比较多的数据
时
,我会考虑设置这两个参数。例如:
exp
userid=test/test file=yw97_2003.dmp log=yw97_2003_3.log feedback=10000 buffer=100000000 tables=WO4,OK_YT 4.FILE和LOG,这两个参数分别指定备份的DMP名称和LOG名称,包括文件名和目录,例子见上面。 5.COMPRESS参数不压缩
导出
数据的内容。用来控制
导出
对象的storage语句如何产生。默认值为Y,
使用
默认值,对象的存储语句的init extent等于当前
导出
对象的extent的总和。推荐
使用
COMPRESS=N。 6. FILESIZE该选项在8i中可用。如果
导出
的dmp文件过大
时
,最好
使用
FILESIZE参数,限制文件大小不要超过2G。如:
exp
userid=duanl/duanl file=f1,f2,f3,f4,f5 filesize=2G owner=scott 这样将创建f1.dmp, f2.dmp等一系列文件,每个大小都为2G,如果
导出
的总量小于10G
EXP
不必创建f5.bmp. IMP常用选项 1、FROMUSER和TOUSER,
使用
它们实现将数据从一个SCHEMA中导入到另外一个SCHEMA中。例如:假设我们做
exp
时
导出
的为test的对象,现在我们想把对象导入用户: imp userid=test1/test1 file=
exp
dat.dmp fromuser=test1 touser=test1 2、IGNORE、GRANTS和INDEXES,其中IGNORE参数将忽略表的存在,继续导入,这个对于需要调整表的存储参数
时
很有用,我们可以先根据实际情况用合理的存储参数建好表,然后直接导入数据。而GRANTS和INDEXES则表示是否导入授权和索引,如果想
使用
新的存储参数重建索引,或者为了加快到入速度,我们可以考虑将INDEXES设为N,而GRANTS一般都是Y。例如:imp userid=test1/test1 file=
exp
dat.dmp fromuser=test1 touser=test1 indexes=N 表空间传输 表空间传输是8i新增加的一种快速在
数据库
间移动数据的一种办法,是把一个
数据库
上的格式数据文件附加到另外一个
数据库
中,而不是把数据
导出
成Dmp文件,这在有些
时
候是非常管用的,因为传输表空间移动数据就象复制文件一样快。 关于传输表空间有一些规则,即: ·源
数据库
和目标
数据库
必须运行在相同的硬件平台上。 ·源
数据库
与目标
数据库
必须
使用
相同的字符集。 ·源
数据库
与目标
数据库
一定要有相同大小的数据块 ·目标
数据库
不能有与迁移表空间同名的表空间 ·SYS的对象不能迁移 ·必须传输自包含的对象集 ·有一些对象,如物化视图,基于函数的索引等不能被传输 可以用以下的方法来检测一个表空间或一套表空间是否符合传输标准: exec sys.dbms_tts.transport_set_check(‘tablespace_name’,true); select * from sys.transport_set_violation; 如果没有行选择,表示该表空间只包含表数据,并且是自包含的。对于有些非自包含的表空间,如数据表空间和索引表空间,可以一起传输。 以下为简要
使用
步骤,如果想参考详细
使用
方法,也可以参考ORACLE联机帮助。 1.设置表空间为只读(假定表空间名字为APP_Data 和APP_Index) alter tablespace app_data read only; alter tablespace app_index read only; 2.发出
EXP
命令 SQL>host
exp
userid=”””sys/password as sysdba””” transport_tablespace=y tablespace=(app_data, app_index) 以上需要注意的是 ·为了在SQL中执行
EXP
,USERID必须用三个引号,在UNIX中也必须注意避免“/”的
使用
·在816和以后,必须
使用
sysdba才能操作 ·这个命令在SQL中必须放置在一行(这里是因为显示问题放在了两行) 3.拷贝数据文件到另一个地点,即目标
数据库
可以是cp(unix)或copy(windows)或通过ftp传输文件(一定要在bin方式) 4.把本地的表空间设置为读写 5.在目标
数据库
附加该数据文件 imp file=
exp
dat.dmp userid=”””sys/password as sysdba””” transport_tablespace=y “datafile=(c:\temp\app_data,c:\temp\app_index)” 6.设置目标
数据库
表空间为读写 alter tablespace app_data read write; alter tablespace app_index read write; 优化
EXP
/IMP的方法: 当需要
exp
/imp的数据量比较大
时
,这个过程需要的
时
间是比较长的,我们可以用一些方法来优化
exp
/imp的操作。
exp
:
使用
直接路径 direct=y oracle会避开sql语句处理引擎,直接从
数据库
文件中读取数据,然后写入
导出
文件. 可以在
导出
日志中观察到:
exp
-00067: table xxx will be
exp
orted in conventional path 如果没有
使用
直接路径,必须保证buffer参数的值足够大. 有一些参数于direct=y不兼容,无法用直接路径
导出
可移动的tablespace,或者用query参数
导出
数据库
子集. 当导入
导出
的
数据库
运行在不同的os下
时
,必须保证recordlength参数的值一致. imp:通过以下几个途径优化 1.避免磁盘排序 将sort_area_size设置为一个较大的值,比如100M 2.避免日志切换等待 增加重做日志组的数量,增大日志文件大小. 3.优化日志缓冲区 比如将log_buffer容量扩大10倍(最大不要超过5M) 4.
使用
阵列插入与提交 commit = y 注意:阵列方式不能处理包含LOB和LONG类型的表,对于这样的table,如果
使用
commit = y,每插入一行,就会执行一次提交. 5.
使用
NOLOGGING方式减小重做日志大小 在导入
时
指定参数indexes=n,只导入数据而忽略index,在导完数据后在通过脚本创建index,指定 NOLOGGING选项
导出
/导入与字符集 进行数据的导入
导出
时
,我们要注意关于字符集的问题。在
EXP
/IMP过程中我们需要注意四个字符集的参数:
导出
端的客户端字符集,
导出
端
数据库
字符集,导入端的客户端字符集,导入端
数据库
字符集。 我们首先需要查看这四个字符集参数。 查看
数据库
的字符集的信息: SQL> select * from nls_database_parameters; PARAMETER VALUE ------------------------------ -------------------------------------------------------------------------------- NLS_LANGUAGE AMERICAN NLS_TERRITORY AMERICA NLS_CURRENCY $ NLS_ISO_CURRENCY AMERICA NLS_NUMERIC_CHARACTERS ., NLS_CHARACTERSET ZHS16GBK NLS_CALENDAR GREGORIAN NLS_DATE_FORMAT DD-MON-RR NLS_DATE_LANGUAGE AMERICAN NLS_SORT BINARY NLS_TIME_FORMAT HH.MI.SSXFF AM NLS_TIMESTAMP_FORMAT DD-MON-RR HH.MI.SSXFF AM NLS_TIME_TZ_FORMAT HH.MI.SSXFF AM TZH:TZM NLS_TIMESTAMP_TZ_FORMAT DD-MON-RR HH.MI.SSXFF AM TZH:TZM NLS_DUAL_CURRENCY $ NLS_COMP BINARY NLS_NCHAR_CHARACTERSET ZHS16GBK NLS_RDBMS_VERSION 8.1.7.4.1 NLS_CHARACTERSET:ZHS16GBK是当前
数据库
的字符集。 我们再来查看客户端的字符集信息: 客户端字符集的参数NLS_LANG=_< territory >. language:指定oracle消息
使用
的语言,日期中日和月的显示。 Territory:指定货币和数字的格式,地区和计算星期及日期的习惯。 Characterset:控制客户端应用程序
使用
的字符集。通常设置或等于客户端的代码页。或者对于unicode应用设为UTF8。 在windows中,查询和修改NLS_LANG可在注册表中进行: HKEY_LOCAL_MACHINE\SOFTWARE\Oracle\HOMExx\ xx指存在多个Oracle_HOME
时
的系统编号。 在unix中: $ env|grep NLS_LANG NLS_LANG=simplified chinese_china.ZHS16GBK 修改可用: $
exp
ort NLS_LANG=AMERICAN_AMERICA.UTF8 通常在
导出
时
最好把客户端字符集设置得和
数据库
端相同。当进行数据导入
时
,主要有以下两种情况: (1) 源
数据库
和目标
数据库
具有相同的字符集设置。 这
时
,只需设置
导出
和导入端的客户端NLS_LANG等于
数据库
字符集即可。 (2) 源
数据库
和目标
数据库
字符集不同。 先将
导出
端客户端的NLS_LANG设置成和
导出
端的
数据库
字符集一致,
导出
数据,然后将导入端客户端的NLS_LANG设置成和
导出
端一致,导入数据,这样转换只发生在
数据库
端,而且只发生一次。 这种情况下,只有当导入端
数据库
字符集为
导出
端
数据库
字符集的严格超集
时
,数据才能完全导成功,否则,可能会有数据不一致或乱码
出现
。 不同版本的
EXP
/IMP问题 一般来说,从低版本导入到高版本问题不大,
麻烦
的是将高版本的数据导入到低版本中,在Oracle9i之前,不同版本Oracle之间的
EXP
/IMP可以通过下面的方法来解决: 1、在高版本
数据库
上运行底版本的cat
exp
.sql; 2、
使用
低版本的
EXP
来
导出
高版本的数据; 3、
使用
低版本的IMP将
数据库
导入到低版本
数据库
中; 4、在高版本
数据库
上重新运行高版本的cat
exp
.sql脚本。 但在9i中,上面的方法并不能解决问题。如果直接
使用
低版本
EXP
/IMP会
出现
如下
错误
:
EXP
-00008: orACLE error %lu encountered orA-00904: invalid column name 这已经是一个公布的BUG,需要等到Oracle10.0才能解决,BUG号为2261722,你可以到METALINK上去查看有关此BUG的详细信息。 BUG归BUG,我们的工作还是要做,在没有Oracle的支持之前,我们就自己解决。在Oracle9i中执行下面的SQL重建exu81rls视图即可。 Create or REPLACE view exu81rls (objown,objnam,policy,polown,polsch,polfun,stmts,chkopt,enabled,spolicy) AS select u.name, o.name, r.pname, r.pfschma, r.ppname, r.pfname, decode(bitand(r.stmt_type,1), 0,'', 'Select,') || decode(bitand(r.stmt_type,2), 0,'', 'Insert,') || decode(bitand(r.stmt_type,4), 0,'', 'Update,') || decode(bitand(r.stmt_type,8), 0,'', 'Delete,'), r.check_opt, r.enable_flag, DECODE(BITAND(r.stmt_type, 16), 0, 0, 1) from user$ u, obj$ o, rls$ r where u.user# = o.owner# and r.obj# = o.obj# and (uid = 0 or uid = o.owner# or exists ( select * from session_roles where role='Select_CATALOG_ROLE') ) / grant select on sys.exu81rls to public; / 可以跨版本的
使用
EXP
/IMP,但必须正确地
使用
EXP
和IMP的版本: 1、总是
使用
IMP的版本匹配
数据库
的版本,如:要导入到817中,
使用
817的IMP工具。 2、总是
使用
EXP
的版本匹配两个
数据库
中最低的版本,如:从9201往817中导入,则
使用
817版本的
EXP
工具。 例子
exp
system/manager@mydb file=my.dmp log=20020101.log owner=scott
exp
用户名/密码@服务名 file=c:\fr_yusnhu.dmp ower=用户
exp
fr_yunshu/fr_yunshu@orcl file=d:\fr_yunshu.dmp owner=fr_yunshu
exp
system/manager@orcl file=111.dmp log=111.log direct=y compress=y feedback=10000
exp
nc50/1 inctype=complete file=E:\data.dmp full=y(
导出
全部)
exp
nc50/1 file=E:\data.dmp OWNER = nc50(
导出
指定用户nc50) imp nc50/1@orcl inctype=complete file=E:\data.dmp full=Y(导入全部) imp nc50/1@orcl file=E:\data.dmp fromuser=nc50 touser=nc50(导入指定用户nc50)
oracle
exp
导出
表where,oracle
EXP
导出
一张表
时
使用
query参数指定where条件
oracle
exp
导出
一个表的部分内容,
使用
query参数可加上SQL的where条件进行过滤 注意:如果需要
使用
到日期字符串格式等单引号,需要
使用
双引号将where条件括起来,而且双引号要用\做转义
exp
test/test@testdb file=D:\test_bak.dmp log=D:\
exp
0811.log tables=(tbl_test) query=\"where st...
CTF之PWN学习入门
从基础开始,一步步教同学们从基础的栈溢出,栈溢出的原理以及在64位程序与32位程序下,如何去构造
EXP
,以及在有一般保护的情况下如你构造ROP链,在没有binsh与system函数的情况下如何去构造泄露如put,printf,write等函数的真实地址。然后教大家格式化字符串漏洞的利用,在开启canary下即存在栈溢出与格式化漏洞的情况下如保构造
EXP
来打通获取一个shell。学完课程同学们能够掌握格式化字符串漏洞与栈溢出漏洞的原理以及如何去构造
EXP
,掌握原理。
使用
Oracle 的 imp ,
exp
命令实现数据的导入
导出
本文对Oracle数据的导入
导出
imp ,
exp
两个命令进行了介绍, 并对其相应的参数进行了说明,然后通过一些示例进行演练,加深理解.
文章最后对运用这两个命令可能
出现
的问题(如权限不够,不同oracle版本)进行了探讨,并提出了相应的解决方案;
本文部分内容摘录自网络,感谢网友的经验总结;
一.说明
oracle 的
exp
/imp命令用于实现对
数据库
的
导出
/导入操作;
exp
命令用于把数据从远程
数据库
服
物化视图是否可以
exp
导出
_ORACLE
EXP
(
导出
)/IMP(导入)的
使用
详解
导入/
导出
是ORACLE幸存的最古老的两个命令行工具,其实我从来不认为
Exp
/Imp是一种好的备份方式,正确的说法是
Exp
/Imp只能是一个好的转储工具,特别是在小型
数据库
的转储,表空间的迁移,表的抽取,检测逻辑和物理冲突等中有不小的功劳。当然,我们也可以把它作为小型
数据库
的物理备份后的一个逻辑辅助备份,也是不错的建议。对于越来越大的
数据库
,特别是TB级
数据库
和越来越多数据仓库的
出现
,
EXP
/IM...
基础和管理
17,377
社区成员
95,128
社区内容
发帖
与我相关
我的任务
基础和管理
Oracle 基础和管理
复制链接
扫一扫
分享
社区描述
Oracle 基础和管理
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章