数据库导入导出expdp,impdp

数据库操作

(1)数据库导入导出expdp,impdp

在导入导出数据库的时候,经常会用到exp和imp,在数据量小的情况下可以随意使用,但是当数据量大,表中数据有百万,千万条的时候,就要等好久好久好久。。
oracle官方肯定也考虑到了这样的问题,于是出现了expdp和impdp,这是oracle 10g版本出的一个新功能,使用数据泵导入导出数据,据官方推荐说使用数据泵导入导出会比普通的导入导出快十倍,可以说是非常强大了。
首先连接到数据库,使用cmd执行以下命令

sqlplus /nolog
conn / as sysdba

数据库泵的步骤(以下是在数据库所在的电脑上操作)

导出数据
  • (a)创建DIRECTORY
    即在数据库所在电脑上创建一个文件夹,用来存放导出的dmp文件
create directory expdp_dmp as 'F:/dmpfile'
  • (b)授权
    给当前数据库用户赋予读写文件的权限
grant read,write on directory expdp_dmp to salespa;

查看权限

SELECT privilege, directory_name, DIRECTORY_PATH FROM user_tab_privs t, all_directories d
?WHERE t.table_name(+) = d.directory_name ORDER BY 2, 1;
  • (c)执行导出
expdp SALESPA/[email protected]  directory=expdp_dmp dumpfile=salespa.dmp
导入数据
impdp E43001/E43001 directory=expdp_dmp dumpfile=salespa.dmp remap_schema=salespa:E43001  transform=OID:N

REMAP_SCHEMA 该参数的含义是将一个用户的的数据迁移到另外一个用户,如上从salespa用户迁移到 E43001用户上。
transform 在导入数据的时候,之前的数据库中可能存在type,把一个Object从一个schema导入到另外一个schema的时候(在同一个数据库上),如果这个OID也保持不变的话,那么就会出现多个Object共享同一个object id的问题,会出现invalid object identifier。
设置transform 参数为OID:N,意思是新创建的表或这个类型会赋予新的OID,而不是dmp文件中包含的OID的值。

参考博客地址:
数据库导入导出exp和expdp以及imp和impdp的区别
ORACLE EXPDP命令使用详细
ORA-02304: ORACLE导入TYPE

(2)cmd执行sql文件

往数据库中插入数据量较大时,例如几万,十几万条的时候,使用PLSQL工具的时候就会卡死。这里就要在命令行中执行sql语句。

//1.首先连接到要连的数据库
sqlplus scott/[email protected]
//[email protected]+“sql文件放置的路径”
SQL> @C:\people.sql

(3)查看Oracle数据库表空间的使用率

SELECT C.TABLESPACE_NAME,
       A.BYTES / 1048576 MEGS_TOTAL,
       (A.BYTES - B.BYTES) / 1048576 MEGS_USED,
       B.BYTES / 1048576 MEGS_FREE,
       (A.BYTES - B.BYTES) / A.BYTES * 100 PCT_USED,
       B.BYTES / A.BYTES * 100 PCT_FREE
  FROM (SELECT TABLESPACE_NAME,
               SUM(A.BYTES) BYTES,
               MIN(A.BYTES) MINBYTES,
               MAX(A.BYTES) MAXBYTES
          FROM SYS.DBA_DATA_FILES A
         GROUP BY TABLESPACE_NAME) A,
       (SELECT A.TABLESPACE_NAME, NVL(SUM(B.BYTES), 0) BYTES
          FROM SYS.DBA_DATA_FILES A, SYS.DBA_FREE_SPACE B
         WHERE A.TABLESPACE_NAME = B.TABLESPACE_NAME(+)
           AND A.FILE_ID = B.FILE_ID(+)
         GROUP BY A.TABLESPACE_NAME) B,
       SYS.DBA_TABLESPACES C
 WHERE A.TABLESPACE_NAME = B.TABLESPACE_NAME(+)
   AND A.TABLESPACE_NAME = C.TABLESPACE_NAME
 ORDER BY 6;

查看所有表空间大小

select tablespace_name,sum(bytes)/1024/1024 from dba_data_files group by tablespace_name;

手动修改表空间的大小

查看表空间的目录
select * from dba_data_file
更改表空间的大小为30G
alter database datafile 'E:\APP\LABOGUEST\SALESPA\SALESPA_INDEX.DBF' resize 30720

(4)ORA-24247: 网络访问被访问控制列表 (ACL) 拒绝

  • 创建访问控制列表
BEGIN
 DBMS_NETWORK_ACL_ADMIN.CREATE_ACL (
  acl          => 'email_server.xml',  --这里为任意的文件名,用于删除时标识
  description  => 'ACL for 123.125.50.112',
  principal    => 'PRODUCE', --此为将来要进行操作的用户
  is_grant     => TRUE,
  privilege    => 'connect');
END;
  • 将用户或角色添加到访问控制列表中
BEGIN
 DBMS_NETWORK_ACL_ADMIN.ADD_PRIVILEGE (
  acl          => 'email_server.xml',  --和创建访问控制列表中的acl名相同
  principal    => 'PRODUCE', --要添加的用户
  is_grant     => TRUE,
  privilege    => 'resolve');
END;
  • 给网络分配访问控制列表(ACL与邮件服务器相关联)
BEGIN
 DBMS_NETWORK_ACL_ADMIN.ASSIGN_ACL (
  acl          => 'email_server.xml',  --和创建访问控制列表中的acl名相同
  host         => '123.125.50.112', --主机名,域名,ip地址或分配的子网
  lower_port   => '25',
  upper_port   => NULL);
END;
  • 查询创建的ACL
SELECT host, lower_port, upper_port, acl FROM dba_network_acls;
SELECT acl,
       principal,
       privilege,
       is_grant,
       TO_CHAR(start_date, 'DD-MON-YYYY') AS start_date,
       TO_CHAR(end_date, 'DD-MON-YYYY') AS end_date
  FROM dba_network_acl_privileges;
  • 删除ACL
BEGIN
  DBMS_NETWORK_ACL_ADMIN.drop_acl(acl => 'email_server.xml');
COMMIT;
END;

(5)解锁被锁的表

在调试程序的时候,有时debug忘记点结束,又去数据库中操作表,很有可能会造成锁表,无法对该表进行操作。以下是查看被锁的表和解锁表的语句。

select a.object_name,b.session_id,c.serial#,c.username,c.command,c.machine,c.lockwait
from all_objects a,v$locked_object b,v$session c where a.object_id=b.object_id and c.sid=b.session_id;

alter system kill session'SID,serial# ';

原文地址:https://www.cnblogs.com/ghq120/p/9824416.html

时间: 2024-12-10 12:48:58

数据库导入导出expdp,impdp的相关文章

expdp impdp 数据库导入导出命令详解

一.创建逻辑目录,该命令不会在操作系统创建真正的目录,最好以system等管理员创建. create directory dpdata1 as 'd:\test\dump'; 二.查看管理理员目录(同时查看操作系统是否存在,因为Oracle并不关心该目录是否存在,如果不存在,则出错) select * from dba_directories; 三.给scott用户赋予在指定目录的操作权限,最好以system等管理员赋予. grant read,write on directory dpdata

oracle数据库导入导出方法

Oracle Database 10g以后引入了最新的数据泵(Data Dump)技术,使DBA或开发人员可以将数据库元数据(对象定义)和数据快速移动到另一个oracle数据库中. 数据泵导出导入(EXPDP和IMPDP)的作用  1.实现逻辑备份和逻辑恢复.  2.在数据库用户之间移动对象.  3.在数据库之间移动对象  4.实现表空间搬移. 数据泵导出导入与传统导出导入的区别: 在10g之前,传统的导出和导入分别使用EXP工具和IMP工具,从10g开始,不仅保留了原有的EXP和IMP工具,还

Oracle数据库导入导出逻辑备份方法总结

[EXP常用参数] USERID  即用户名/密码该参数就必须且为第一个: FILE    指定数据输出文件路径: LOG     指定日志输出文件路径: TABLES  导出指定表数据: FULL    完全导出整个文件(N): ROWS    导出数据行(Y): QUERY   用于导出表的子集的 select 子句: [示例] 1.[全库模式]将数据库orcl完全导出,用户名scott密码scott数据文件导出到D:/orcl/scott.dmp,日志文件到出到D:/orcl/scott.

Linux下Oracle启动、建立表空间、用户、授权、数据库导入导出

1.1进入到sqlplus启动实例 [[email protected] ~]$ su - oracle                                 --“切换到oracle用户”[[email protected] ~]$ lsnrctl start                               --“打开监听”[[email protected] ~]$ sqlplus /nolog                                --“进入到

03.01 Oracle数据泵导出导出(expdp/impdp)命令举例(上)

Oracle数据泵导出导出(expdp/impdp)命令举例(上) ##实验目的: 使用数据泵迁移数据 ##实验环境: Oracle 11.2.0.4,利用数据库自带的scott示例用户进行试验测试 实验步骤概述: 1.首先需要创建Directory 2.使用expdp导出用户数据 2.1 只导出scott用户的元数据,且不包含统计信息: 2.2 只导出scott用户的数据: 2.3 只导出scott用户下的emp,dept表及数据: 2.4 只导出scott用户下的emp,dept表结构: 2

功能齐全、效率一流的免费开源数据库导入导出工具(c#开发,支持SQL server、SQLite、ACCESS三种数据库),每月借此处理数据5G以上

软件名:DataPie 功能:支持SQL server.SQLite.ACCESS数据库的导入.导出.存储过程调用,支持EXCEL2007.EXCEL2003.ACCESS2007. CSV文件导入数据库,支持EXCEL.CSV.ZIP.ACCESS文件方式导出,支持数据拆分导出及自定义SQL查询与导出. 开发背景:作者从事财务管理工作,主要是出具集团的内部财务报表,随着公司精细化管理的需求,管理报表的数据量急速增长, 依赖EXCEL加工处理数据已经变得极为困难,因此团队全面转向关系数据库进行数

mysql数据库导入导出及修改数据库名命令

概述 mysql 数据库导入导出,有两种方式 1)先导出SQL脚本,再导入(导入导出又分两种:1. 命令. 2. 工具.这里我们只介绍命令). 2)直接拷贝数据库文件(此方法不推荐). 一.mysql数据库导入 1.  已有数据库,可以直接用mysql命令 命令格式 mysql -u用户名 -p密码 数据库名 <  sql文件路径 示例:mysql -uroot -p12345678  test <  /root/test.sql 2.  创建新数据导入 mysql -uroot -p1234

linux系统上Mysql数据库导入导出操作

需求:把MySQL数据库目录中的dz数据库备份到/home/dz_bak.sql ,然后再新建一个数据库dzbak,最后把/home/dz_bak.sql 导入到数据库dzbak中.操作如下:以下操作均在终端命令行下进行 1.mysqldump -u root -p dz > /home/dz_bak.sql        #导出数据库     123456     #输入数据库密码     扩展:     mysqldump -u root -p dz pre_portal_comment >

oracle数据库导入导出命令!

Oracle数据导入导出imp/exp 功能:Oracle数据导入导出imp/exp就相当与oracle数据还原与备份. 大多情况都可以用Oracle数据导入导出完成数据的备份和还原(不会造成数据的丢失). Oracle有个好处,虽然你的电脑不是服务器,但是你装了oracle客户端,并建立了连接 (通过Net Configuration Assistant添加正确的服务命名,其实你可以想成是客户端与服务器端 修了条路,然后数据就可以被拉过来了) 这样你可以把数据导出到本地,虽然可能服务器离你很远