oracle导入导出单个表的办法

1.首先是导出几张表的数据、结构;可以用plsql工具,也可以用命令。

plsql工具:


命令:

导出数据库
操作:运行:cmd 然后输入:
exp lw/lw@ORCL file=d:\lw.dmp tables=(tablename1,tablename1) owner=(lw);

2.导入数据库
操作:运行:cmd 然后输入:根据主外键顺序来导入数据,不然是导入不全的。
imp username/password@本地net服务名 file=xxx.dmp fromuser=energy touser=energy1 tables=(tablename)  ignore=y;

ignore=y加上这个有表的情况下忽略,也就是出现相同记录的忽略,没有记录的插入。这样问题又来了相同记录需要更新怎么办?


3.更新数据库:

A.在本地建立一个用户test,记住表空间名称需要一样的。

imp username/password@本地net服务名 file=xxx.dmp fromuser=energy touser=test full=y;

直接全部导入数据库

B.在真正需要导入数据库里建立几个临时表,可以根据表结构sql来创建,只保留主键就行了,外键不用。

然后把用户test的表查询的数据全部复制,粘贴到临时表里:

写一个存储过程:

create or replace procedure CHECK_DATA
is
 type sp_test1_cursor is ref cursor;
         cur_m_energy sp_test1_cursor;
        ENERGYNO_TEMP M_ENERGY_TEMP.ENERGYNO%type;
    begin
     open cur_m_energy for  select
    ENERGYNO
    from M_ENERGY_TEMP ;
      Loop
        fetch cur_m_energy
          into ENERGYNO_TEMP;
        exit when cur_m_energy%NOTFOUND;
      
          update TEST1 a
             set a.ENERGYNAME = (select ENERGYNAME from M_ENERGY_TEMP t where t.energyno=ENERGYNO_TEMP ),
             a.ENERGYUNIT=(select ENERGYUNIT from M_ENERGY_TEMP t where t.energyno=ENERGYNO_TEMP ),
             a.ENERGYTYPE=(select ENERGYTYPE from M_ENERGY_TEMP t where t.energyno=ENERGYNO_TEMP ),
             a.REMARK=(select REMARK from M_ENERGY_TEMP t where t.energyno=ENERGYNO_TEMP ),
             a.STATUS=(select STATUS from M_ENERGY_TEMP t where t.energyno=ENERGYNO_TEMP ),
             a.SORTNO=(select SORTNO from M_ENERGY_TEMP t where t.energyno=ENERGYNO_TEMP )
           where a.ENERGYNO = ENERGYNO_TEMP;
          commit;
      end loop;
    close cur_m_energy;

end CHECK_DATA;


sql窗口执行就可以了:call  CHECK_DATA();



cmd窗口也可以:

sqlplus

输入账号,密码 执行存储过程

exec CHECK_DATA();
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle RAC 数据库中的数据导出单个实例数据库可以通过以下步骤完成: 1. 在单个实例数据库上创建一个新的目录,用于存放导出文件。 2. 确定需要导出空间,或者架构,并在单实例数据库中创建相应的空间和用户账户。 3. 使用 `expdp` 命令导出数据,例如: ``` expdp system/password directory=<导出目录> dumpfile=<导出文件名>.dmp logfile=<日志文件名>.log include=<需要导出的对象> exclude=<不需要导出的对象> ``` 其中,`<导出目录>` 是第 1 步中创建的目录名称,`<导出文件名>` 和 `<日志文件名>` 分别是导出数据的文件名和日志文件名,`<需要导出的对象>` 和 `<不需要导出的对象>` 分别是需要导出和不需要导出的对象名称,可以使用通配符进行匹配。 4. 确认导出文件已经生成,并将其拷贝到单实例数据库的目录中。 5. 在单实例数据库中使用 `impdp` 命令导入数据,例如: ``` impdp system/password directory=<导入目录> dumpfile=<导出文件名>.dmp logfile=<日志文件名>.log remap_schema=<旧用户名>:<新用户名> remap_tablespace=<旧空间名>:<新空间名> ``` 其中,`<导入目录>` 是第 1 步中创建的目录名称,`<导出文件名>` 和 `<日志文件名>` 分别是导出数据的文件名和日志文件名,`<旧用户名>` 和 `<新用户名>` 分别是旧的和新的用户名,`<旧空间名>` 和 `<新空间名>` 分别是旧的和新的空间名称。 6. 确认数据已经导入成功,并进行必要的验证和测试。 需要注意的是,在数据导出导入过程中,需要确保数据库版本和参数配置的一致性,以及数据的完整性和一致性。此外,如果需要导出导入其他对象(如存储过程、触发器等),则需要相应地调整 `include` 和 `exclude` 参数。 希望以上步骤和命令能够帮助到你完成数据导出导入。如果还有其他问题或者需要更详细的解答,请随时提出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值