Chinaunix首页 | 论坛 | 博客
  • 博客访问: 663126
  • 博文数量: 109
  • 博客积分: 6081
  • 博客等级: 准将
  • 技术积分: 1318
  • 用 户 组: 普通用户
  • 注册时间: 2009-10-24 10:28
文章分类
文章存档

2011年(8)

2010年(39)

2009年(62)

分类: Oracle

2009-12-01 16:26:35


导出前数据库状况:
------------------------------------------------------------------------------------------------------------------
1、表空间:study   大小 200M,有两个文件
/oracle/oradata/study/studydata1.bdf
/oracle/oradata/study/studydata2.bdf

2、用户 test/test
权限:
SQL>select * from user_sys_privs;
TEST                           CREATE TABLE                             NO
TEST                           CREATE SESSION                           NO
TEST                           UNLIMITED TABLESPACE                     NO
或者
SQL> select * from session_privs;

PRIVILEGE
----------------------------------------
CREATE SESSION
UNLIMITED TABLESPACE
CREATE TABLE

角色:
SQL> select * from user_role_privs;

USERNAME                       GRANTED_ROLE                   ADM DEF OS_
------------------------------ ------------------------------ --- --- ---
TEST                           CONNECT                        NO  YES NO

默认表空间:study
SQL>select username,default_tablespace from user_users;  //dba_users 适用于DBA 用户,查看任何用户的默认表空间                            
USERNAME                       DEFAULT_TABLESPACE
------------------------------ ------------------------------
TEST                           STUDY

所拥有的对象
SQL> select * from user_objects;  //dba_objects 适用于dba 用户查询
OBJECT_NAME              OBJECT_ID DATA_OBJECT_ID OBJECT_TYPE         CREATED   LAST_DDL_ TIMESTAMP           STATUS  T G S
---------------------------------------------------------------------------------------------------------
STUDENT                    51255           51255 TABLE               28-NOV-09 28-NOV-09 2009-11-28:06:36:20 VALID   N N N
SYS_C005250                51256           51256 INDEX               28-NOV-09 28-NOV-09 2009-11-28:06:36:21 VALID   N Y N
TEST                       51257           51257 TABLE               28-NOV-09 28-NOV-09 2009-11-28:06:36:22 VALID   N N N
TESTTABLE                  51258           51258 TABLE               28-NOV-09 28-NOV-09 2009-11-28:06:36:22 VALID   N N N

--------------------------------------------------------------------------------------------------------------
对象在表空间中的分布:(方便确认)
SQL> select table_name,tablespace_name from user_tables;  

TABLE_NAME                     TABLESPACE_NAME
------------------------------ ------------------------------
STUDENT                        USERS
TEST                           STUDY
TESTTABLE                      STUDY

SQL> select index_name,table_name,table_owner from user_indexes;   //dba_indexes 使用于dba 用户查看所有用户

INDEX_NAME                     TABLE_NAME                     TABLE_OWNER
------------------------------ ------------------------------ ------------------------------
SYS_C005250                    STUDENT                        TE


数据库导出实例
-----------------------------------------------------------------------------------------------------------------
1、全库导出导入实例
SQL> create user backup identified by backup;  
SQL>GRANT CREATE USER,DROP USER,ALTER USER ,CREATE ANY VIEW ,
    DROP ANY VIEW,EXP_FULL_DATABASE,IMP_FULL_DATABASE,
    DBA,CONNECT,RESOURCE,CREATE SESSION  TO backup;
$  exp backup/backup file=backup.dump full=yes  compress=n
$  imp backup/backup file=backup.dump full=yes  commit=yes ignore=yes     //注意原来的表空间文件已经存在时,要删除,否则创建表空间失败,致使导入失败

$  exp system/oracle file=full.dump full=yes  compress=n                       
$  imp system/oracle file=full.dump full=yes   ignore=yes                 //注意原来的表空间文件已经存在时,要删除,否则创建表空间失败,致使导入失败


$  exp \'sys/oracle as sysdba\' file=fullsys.dump full=yes  compress=n
$  imp \'sys/oracle as sysdba\' file=fullsys.dump full=yes  ignore=yes    //注意原来的表空间文件已经存在时,要删除,否则创建表空间失败,致使导入失败

数据库破坏处理
SQL> drop user test cascade;
SQL> drop tablespace study including contents;
#rm -f  /oracle/oradata/study/studydata*  //删除原来表空间的数据文件。


2、按用户导出导入实
-----------------------------------------------------------------------------------------------------------------
$  exp test/test file=test.dump compress=no
$  imp test/test file=test.dump ignore=yes

导入数据库前。新建test 用户
SQL > create user test identified by test;
SQL > grant create session,create table,unlimited tablespace to test;  //确保该用户有连接权限,创建表格权限,对表空间的写权限。

数据库破坏处理:
SQL> drop user test cascade;


3、按表空间导出导入实例
----------------------------------------------------------------------------------------------------------------
1、表空间在数据库之间移动:
SQL> alter tablespace study read only;
   $ exp \'sys/oracle as sysdba\'  transport_tablespace=y tablespaces=study  file=study.dmp
 
 进入目标机器上,创建对应表空间的用户,不必指定缺省表空间。
把study.dmp,及该表空间的数据文件/studydata1.bdf,/studydata2.bdf  --  ftp 或cp 到别的机器。

SQL> create user test identified by test;
$ imp file=study.dmp userid=\'sys/oracle as sysdba\' transport_tablespace=y datafiles='/oracle/oradata/study/studydata1.bdf','/oracle/oradata/study/studydata1.bdf' ignore=yes

数据库破坏处理:
SQL> drop tablespace study including contents;


4、数据库文件损坏处理实例
----------------------------------------------------------------------------------------------------------------
误删除一下文件:
#rm -f  /oracle/oradata/study/studydata*  //删除原来表空间的数据文件。
SQL > shutdown immediate;
SQL > startup mount;
SQL > alter database datafile '/oracle/oradata/study/studydata1.bdf' offline drop;
SQL > alter database datafile '/oracle/oradata/study/studydata2.bdf' offline drop;
SQL> alter database open;
Database altered.

SQL> drop tablespace study;
Tablespace dropped.

进行全库导入恢复处理:
$ imp system/oracle file=full.dump full=yes   ignore=yes                 //注意原来的表空间文件已经存在时,要删除,否则创建表空间失败,致使导入失败


 
阅读(1393) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~