一、了解oracle数据库的一些概念
- 一个数据库——多个数据库实例(这里和下面的‘——’是对应的意思)
- 一个数据库实例——多个表空间(表空间是数据库的逻辑划分,每个数据库至少一个表空间)
- 一个表空间——多个表
数据库的创建有这样的顺序:表空间——>用户——>给用户分权限——>表
二、导出操作(按照下面的操作进行导出)
1、导出表结构和数据:
expdp SCHEMA名/SCHEMA对应的密码 directory=tmp_dir dumpfile=file0921.dmp logfile=result.log FULL=Y
//tmp_dir为导出的目录,需要自己预先创建,创建后导出的文件file0921.dmp就在目录/oracle/tmp_dir下面
//SCHEMA为对应库的名字,oracle可以有多个SCHEMA,导出导入需要分开执行
或导出表结构不带数据
expdp SCHEMA名/SCHEMA对应的密码 directory=tmp_dir dumpfile=file0921.dmp logfile=result.log owner=用户名 rows=n;
2、创建表空间
create tablespace TS_NPFDB logging datafile '/oradata/directory/npfdb01.dbf' size 2G autoextend on next 5G maxsize 30G extent management local;
//此处需要根据你磁盘的大小进行设置,表空间尽量设计大一些,避免后期调整带来的麻烦
3、创建用户
CREATE USER 用户名 IDENTIFIED BY 密码 DEFAULT TABLESPACE "TS_NPFDB" TEMPORARY TABLESPACE "TEMP";
GRANT "DBA" TO 用户名 ;
GRANT "CONNECT" TO 用户名 ;
GRANT "RESOURCE" TO 用户名 ;
//在用户名和密码的位置更换自己想要创建的用户名,及其对应的密码
三、导入操作 (按照下面的操作进行导入)
1、复制数据库文件到将要执行导入的机器
使用scp命令将导出的file0921.dmp复制到需要导入的机器上的oracle目录下,这个scp可以在导出的机器上执行,也可以再将要导入的机器上执行,不会操作的可以给我留言
2、给予数据文件可执行权限
chmod 775 NETPAY20200811.dmp
3、执行导入操作
impdp 用户名/密码 DIRECTORY=dpdata1 DUMPFILE=file0921.dmp SCHEMAS=SCHEMA名;
四、数据库导出导入操作可能会用到的命令大全
- 查看已存在表空间的命令:select file_id, tablespace_name from dba_data_files;
- 删除已存在的表空间的命令:drop tablespace TS_DATA_NPFBK including contents and datafiles cascade constraint;
- 查看已存在的用户和密码的命令:select username, password from dba_users;
- 删除已存在的用户的命令:drop user username cascade;
- sql中创建导入路径命令create or replace directory dpdata1 as '/oracle';
- sql中给导入用户权限命令grant read, write on directory dpdata1 to username;
- 查看用户下的所有表名:select table_name from all_tables where owner='username';
- 查看所有用户及其对应的表空间select username,default_tablespace from dba_users;
- 查看所有表空间对应的数据文件select tablespace_name,file_name from dba_data_files;
- 查看表空间的位置 select * from dba_data_files WHERE tablespace_name = 'TS_DATA_NPFBK';
- 重新定义表空间大小alter tablespace TS_DATA_NPFBK resize 5G ;
- 修改数据文件大小alter database datafile '/oradata/directory/npfbk01.dbf' RESIZE 4G;
- 修改数据文件自动增长alter database datafile '/oradata/directory/npfbk02.dbf' autoextend on next 10G maxsize 15G
- 增加数据文件个数alter tablespace TS_DATA_NPFBK add datafile '/oradata/directory/npfbk02.dbf' size 5G;
- alter tablespace TS_NPFDB add datafile '/oradata/directory/npfdb02.dbf' size 10G;
- 查看数据库实例的状态select instance_name, status from v$instance;
- 查询所有的schema所占空间大小
//消耗的总磁盘空间(包括索引、表空间空闲空间),单位G
Select owner, sum(bytes)/1024/1024/1024 schema_size_gig from sys.dba_segments group by owner;
- 表空间已使用大小
select d.tablespace_name, d.totalSize - f.freeSize "已使用空间(M)" from ( SELECT DD.TABLESPACE_NAME,ROUND(SUM(DD.BYTES) / (1024 * 1024), 2) totalSize FROM SYS.DBA_DATA_FILES DD GROUP BY DD.TABLESPACE_NAME ) d, ( SELECT TABLESPACE_NAME, ROUND(SUM(BYTES) / (1024 * 1024), 2) freeSize FROM SYS.DBA_FREE_SPACE GROUP BY TABLESPACE_NAME ) f where d.TABLESPACE_NAME = f.TABLESPACE_NAME
- 查询所有schema
//一个用户(user)对应一个方案(schema)
select username from sys.dba_users
- 查询shema下的所有表
select table_name from sys.dba_tables where owner='schema名';
查询所有的schema及所属的所有表
select s.username "schema",t.table_name "table_name" from sys.dba_users s left join sys.dba_tables t on s.username=t.owner order by s.username asc;
- 查询指定schema各segment_type占用空间大小
Select sum(bytes)/1024/1024/1024 as size_in_gig, segment_type from dba_segments where owner='SCOTT' group by segment_type;
- Drop Table 之后,如果空间不能回收,需要执行下面语句
清除当前用户的回收站:purge recyclebin;
清除所有用户的回收站:purge dba_recyclebin;
- 通过指定表空间查询所属的表名
select Table_Name, Tablespace_Name from Dba_Tables where Tablespace_Name = 'USERS';
- 通过指定表空间查询所属表的占用空间
select segment_name, bytes/1024||'KB' "占用空间" from user_segments where segment_type='TABLE' and tablespace_name='USERS' order by segment_name asc;
- 查看表空间的空间使用情况,包括总大小、已使用和闲置
select a.tablespace_name, a.bytes / 1024 / 1024 "Sum MB", (a.bytes - b.bytes) / 1024 / 1024 "used MB", b.bytes / 1024 / 1024 "free MB", round(((a.bytes - b.bytes) / a.bytes) * 100, 2) "percent_used" from (select tablespace_name, sum(bytes) bytes from dba_data_files group by tablespace_name) a, (select tablespace_name, sum(bytes) bytes, max(bytes) largest from dba_free_space group by tablespace_name) b where a.tablespace_name = b.tablespace_name order by ((a.bytes - b.bytes) / a.bytes) desc;
- 以可理解的单位显示文件大小du -h mobile01.dbf