
Oracle的导出实用程序(Export utility)允许从数据库提取数据 并且将数据写入 *** 作系统文件 exp使用的基本格式 exp[username[/password[@service]]] 以下例举exp常用用法 获取帮助 exp help=y 导出一个完整数据库 exp system/manager file=bible_db log=dible_db full=y 导出数据库定义而不导出数据 exp system/manager file=bible_db log=dible_db full=y rows=n 导出一个或一组指定用户所属的全部表 索引和其他对象 exp system/manager file=seapark log=seapark owner=seaparkexp system/manager file=seapark log=seapark owner=(seapark amy amyc harold)注意 在导出用户时 尽管已经得到了这个用户的所有对象 但是还是不能得到这些对象引用的任何同义词 解决方法是用以下的SQLPlus命令创建一个脚本文件 运行这个脚本文件可以获得一个重建seapark所属对象的全部公共同义词的可执行脚本 然后在目标数据库上运行该脚本就可重建同义词了 SET LINESIZE SET PAGESIZE SET TRIMSPOOL ONSPOOL c:\seapark synSELECT Create public synonym ||synonym_name|| for ||table_owner|| ||table_name|| ; FROM dba_synonymsWHERE table_owner = SEAPARK AND owner = PUBLIC ;SPOOL OFF 导出一个或多个指定表 exp seapark/seapark file=tank log=tank tables=tankexp system/manager file=tank log=tank tables=seapark tankexp system/manager file=tank log=tank tables=(seapark tank amy artist) 估计导出文件的大小 全部表总字节数 SELECT sum(bytes) FROM dba_segments WHERE segment_type = TABLE ;seapark用户所属表的总字节数 SELECT sum(bytes)FROM dba_segmentsWHERE owner = SEAPARK AND segment_type = TABLE ;seapark用户下的aquatic_animal表的字节数 SELECT sum(bytes)FROM dba_segmentsWHERE owner = SEAPARK AND segment_type = TABLE AND segment_name = AQUATIC_ANIMAL ; 导出表数据的子集(oracle i以上) NT系统 exp system/manager query= Where salad_type= FRUIT tables=amy salad_type file=fruit log=fruitUNIX系统 exp system/manager query=\ Where salad_type=\ FRUIT\ \ tables=amy salad_type file=fruit log=fruit 用多个文件分割一个导出文件 exp system/manager file=(paycheck_ paycheck_ paycheck_ paycheck_ )log=paycheck filesize= G tables=hr paycheck 使用参数文件 exp system/manager parfile=bible_tables parbible_tables par参数文件 #Export the sample tables used for the Oracle i Database Administrator s Bible file=bible_tableslog=bible_tablestables=(amy artistamy booksseapark checkupems) 增量导出 完全 增量导出(plete) 即备份整个数据库 exp system/manager inctype=plete file= dmp 增量型 增量导出(incremental) 即备份上一次备份后改变的数据 exp system/manager inctype=incremental file= dmp 累计型 增量导出(cumulative) 即备份上一次 完全 导出之后改变的数据 exp system/manager inctype=cumulative file= dmp lishixinzhi/Article/program/Oracle/201311/17383
如果你管理的Oracle数据库下某些应用项目有大量的修改删除 *** 作 数据索引是需要周期性的重建的
它不仅可以提高查询性能 还能增加索引表空间空闲空间大小
在ORACLE里大量删除记录后 表和索引里占用的数据块空间并没有释放
重建索引可以释放已删除记录索引占用的数据块空间
转移数据 重命名的方法可以重新组织表里的数据
下面是可以按ORACLE用户名生成重建索引的SQL脚本
SET ECHO OFF; SET FEEDBACK OFF; SET VERIFY OFF; SET PAGESIZE ; SET TERMOUT ON; SET HEADING OFF; ACCEPT username CHAR PROMPT Enter the index username: ; spool /oracle/rebuild_&username sql; SELECT REM + + || chr( ) || REM | INDEX NAME : || owner || || segment_name || lpad( | (length(owner) + length(segment_name)) ) || chr( ) || REM | BYTES : || bytes || lpad ( | (length(bytes)) ) || chr( ) || REM | EXTENTS : || extents || lpad ( | (length(extents)) ) || chr( ) || REM + + || chr( ) || ALTER INDEX || owner || || segment_name || chr( ) || REBUILD || chr( ) || TABLESPACE || tablespace_name || chr( ) || STORAGE ( || chr( ) || INITIAL || initial_extent || chr( ) || NEXT || next_extent || chr( ) || MINEXTENTS || min_extents || chr( ) || MAXEXTENTS || max_extents || chr( ) || PCTINCREASE || pct_increase || chr( ) || ); || chr( ) || chr( ) FROM dba_segments WHERE segment_type = INDEX AND owner= &username ORDER BY owner bytes DESC; spool off;
如果你用的是WINDOWS系统 想改变输出文件的存放目录 修改spool后面的路径成
spool c oraclerebuild_&username sql
如果你只想对大于max_bytes的索引重建索引 可以修改上面的SQL语句
在AND owner= &username 后面加个限制条件 AND bytes> &max_bytes
如果你想修改索引的存储参数 在重建索引rebuild_&username sql里改也可以
比如把pctincrease不等于零的值改成是零
生成的rebuild_&username sql文件我们需要来分析一下 它们是否到了需要重建的程度
分析索引 看是否碎片严重 SQL>ANALYZE INDEX &index_name VALIDATE STRUCTURE; col name heading Index Name format a col del_lf_rows heading Deleted|Leaf Rows format col lf_rows_used heading Used|Leaf Rows format col ratio heading % Deleted|Leaf Rows format SELECT name del_lf_rows lf_rows del_lf_rows lf_rows_used to_char(del_lf_rows / (lf_rows) ) ratio FROM index_stats where name = upper( &index_name );
当删除的比率大于 % 时 肯定是需要索引重建的
经过删改后的rebuild_&username sql文件我们可以放到ORACLE的定时作业里
比如一个月或者两个月在非繁忙时间运行
如果遇到ORA 错误 表示索引在的表上有锁信息 不能重建索引
那就忽略这个错误 看下次是否成功
对那些特别忙的表要区别对待 不能用这里介绍的方法
lishixinzhi/Article/program/Oracle/201311/19038
以上就是关于Oracle导出程序Exp的使用具体过程全部的内容,包括:Oracle导出程序Exp的使用具体过程、在Oracle数据库中按用户名重建索引的方法、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)