新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
在平时做Oracle的备份的时候一般都是做逻辑热备份,而做逻辑热备份一般都是使用exp/imp,在这里就简单的说一说。
创新互联建站专注为客户提供全方位的互联网综合服务,包含不限于网站制作、成都做网站、柳林网络推广、微信平台小程序开发、柳林网络营销、柳林企业策划、柳林品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联建站为所有大学生创业者提供柳林建站搭建服务,24小时服务热线:13518219792,官方网址:www.cdcxhl.com
使用exp导出数据imp导入数据操作如下:
exp username/password owner=backup file=backup.dmp imp username/password file=backup.dmp ignore=y full=y
在这里解释一下其中ignore=y表示忽略创建错误,继续后面的操作,这个参数在full=y表示全部导入包括表约束这些内容,这个参数在导入时比较重要。
不过在这里需要注意的一点是在Oracle 11g版本开始后添加了一个新特性当表无数据时,不分配segment,以节省空间,而缺省下这个功能都是开启的,可以通过以下方法查看:
sql> show parameter deferred_segment_creation;
所以在11g的版本后要使用exp导出时还需要做相应的检查,当然因为这个特性使得在11g版本使用exp导出时遇到空表就不会导出,这个问题在也有很多的解决方案,当然个人比较认可的方法应该是在导出前关闭deferred_segment_creation的功能然后检查所有的空表,然后再给找到的所有空表分配空间,操作如下:
sql> alter system set deferred_segment_creation=false; sql> select table_name from user_tables where NUM_ROWS=0; sql> select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0
此时再用exp导出即可