在oracle中怎样把一个数据库中的一张表的数据复制到另一个数据库中的一张表中

在oracle中怎样把一个数据库中的一张表的数据复制到另一个数据库中的一张表中,第1张

1、使用plsql连接上数据,展开【Tables】菜单项,下面出现的就是数据库表。

2、在数据库表tblTest上面点击鼠标右键,选择【Query data】,此项的目的是查询这张数据库表的数据。

3、点击完成【Query data】之后,右侧会出现一个SQL语句的窗口,默认有一条【select * from 表名】的sql语句,下方还有一个列表,展示这张表中的已有数据。

4、然后写一条insert插入的SQL语句,写完之后,选中这条SQL,点击左上角的【次轮状】图标,然后,SQL语句下方会出现【1 row inserted in xx seconds】,表示语句执行成功。此时数据还没有真正写入数据库 insert插入sql格式:insert into 表名(字段1, 字段2, 字段n) values(值1, 值2, 值n)。

5、在Oracle数据库中,对数据的变更还需要点击【Commit】按钮,也就是左上角向下箭头的图标,如果不点击这个按钮,数据其实不会真正存入数据库。点击【Commit】按钮后,会d出一个Confirm窗口,此时点击【Yes】就将数据写入数据库,点击【No】则不提交到数据库。

首先,使用下面的命令移动:

alter table table_name move tablespace tablespace_name

然后,如果有索引的话必须重建索引:

alter index index_name rebuild tablespace tablespace_name

当然,可以使用spool来帮助实现多个表的 *** 作.

set header off

spool /export/home/oracle/alter_tables.sql

select 'alter table ' || object_name || ' move tablespace users'

from dba_object

where owner = 'XXX' and object_type = 'TABLE'

spool off

之后执行此sql脚本即可.

同样对于index也做同样的 *** 作.

大致有两种方法:

1.可以通过expdp 或者exp将这个表先从数据库导出,然后再impdp或者imp导入到另外一个数据库。

2. 可以通过dblink方式(详细方法可以网上搜一下)。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9891201.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存