Oracle导出导出有两中方式:第一段:利用exp imp导出导入;第二段:利用Oracel数据泵expdp impdp导出导入.
第一段:利用exp imp导出导入
exp imp 语法如下:
exp:
①.) 将数据库orcl完全导出
imp:
①.) 将备份文件bak.dmp导出数据库
如果数据表中表已经存在,会提示错误,在后面加上ignore=y就可以了.
解决办法:
①.、设置deferred_segment_creation参数为false后,无论是空表,还是非空表,都分配segment.
在sqlplus中,执行如下命令:
SQLalter system set deferred_segment_creation=false;
查看:
SQLshow parameter deferred_segment_creation;
该值设置后,只对后面新增的表起作用,对之前建立的空表不起作用,并且注意要重启数据库让参数生效.
使用 ALLOCATE EXTEN可以为数据库对象分配Extent,语法如下:
alter table table_name allocate extent
构建对空表分配空间的SQL命令:
SQLselect 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0
批量生成要修改的语句.
然后执行这些修改语句,对所有空表分配空间.
此时用exp命令,可将包括空表在内的所有表导出.
第二段:利用expdp impdp导出导入
在Oracle10g中exp imp被重新设计为Oracle Data Pump(保留了原有的 exp imp工具)
数据泵与传统导出导入的区别;
expdp导出数据:
①.、为输出路径建立一个数据库的directory对象.
create or replace directory dumpdir as 'd:\';
可以通过:select * from dba_directories;查看.
grant read,write on directory dumpdir to test_expdp;
expdp test_expdp/test_expdp directory=dumpdir dumpfile=test_expdp_bak.dmp logfile=test_expdp_bak.log schemas=test_expdp
注意:这句话在cmd窗口中运行,并且最后不要加分号,否则会提示错误.因为这句话是操作系统命令而不是SQL.
impdp导入数据:
①.、给将要进行数据导入的用户授权访问.
grant read,write on directory dumpdir to test_impdp;
impdp test_impdp/impdp directory=dumpdir dumpfile=test_expdp_bak.dmp remap_schema=test_expdp:test_impdp
oracle中function是函数,而procedure是存储过程.
函数:
函数用于返回特定数据.执行时得找一个变量接收函数的返回值.
语法如下:
create or replace function function_name
(
argu1 [mode1] datatype1,
)
return datatype
is
begin
end;
存储过程:
存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,存储在数据库中,经过第一次编译后再次调用不需要再次编译,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它.存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程.
CREATE OR REPLACE PROCEDURE 存储过程名
IS
BEGIN
NULL;
END;
导出dmp:选择oracle导出,找到bin下面的imp.exe,设定导出文件名导出
导出表数据,查询全表数据(不带rowid),全部选中右键导出SQL文件
以上就是土嘎嘎小编为大家整理的如何导出oracle函数相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!