开发者社区> jeanron100> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

关于导入导出sequence

简介: sequence在平时的工作中是一个默默无闻的角色。可能创建好之后很少会去修改它,它就在默默地自增长。直到一些特殊的原因导致sequence出现问题,比如提供了一个脚本,需要使用insert语句修复一些问题, 修复的语句类似insert into test values(100,xxxxxx,xxxx); 正确的写法应该是insert into test values(test_seq.nextval,xxxxxx,xxxx); 但是测试的时候也没有发现问题,就这样部署到生产中就出现问题了。
+关注继续查看
sequence在平时的工作中是一个默默无闻的角色。可能创建好之后很少会去修改它,它就在默默地自增长。直到一些特殊的原因导致sequence出现问题,比如提供了一个脚本,需要使用insert语句修复一些问题,
修复的语句类似insert into test values(100,xxxxxx,xxxx);
正确的写法应该是insert into test values(test_seq.nextval,xxxxxx,xxxx);
但是测试的时候也没有发现问题,就这样部署到生产中就出现问题了。这个时候就是比较典型的sequence不一致问题,可能sequence的nextval是100,但是已经手工插入了一些100,101的数据,这样sequence递增的时候就会出现问题。
所以说sequence的问题发生时,情况还是比较严重的。
在各个环境之间导入导出数据的时候,sequence也是一个不可忽视的环节。数据的导入导出不会默认调用sequence,所以如果不能合理的处理sequence问题,就很可能影响到imp/impdp的进度,甚至导致很多数据问题。
但是在oracle中关于sequence的处理还是一个比较纠结的部分。
oracle没有显示提供工具来做sequence的导入导出,但是工具是死的,人是活的还是有一些途径来完成sequence的导入导出。
有两种主流的处理方法,一种是使用dbms_metadata来导出创建语句,另外一种是直接访问数据字典表,直接生成创建语句。
还有一种方法可以弥补以上两种方法的不足。我都一一做解释。
使用dbms_metadata导出sequence
这种方法也是比较正统的方法。在数据导出的时候可以同时导出一份sequence的脚本。
可以采用如下的脚本来实现。
set linesize 200
col create_ddl format a200
set long 9999
set pages 0
select dbms_metadata.get_ddl('SEQUENCE',u.object_name)||';' create_ddl from user_objects u where object_type='SEQUENCE'

脚本运行情况如下:
SQL> select dbms_metadata.get_ddl('SEQUENCE',u.object_name)||';' create_ddl from user_objects u where object_type='SEQUENCE';

   CREATE SEQUENCE  "N1"."TEST_SEQ2"  MINVALUE 1 MAXVALUE 9999999999999999999999999999 INCREMENT BY 1 START WITH 1 NOCACHE  ORDER  CYCLE ;

   CREATE SEQUENCE  "N1"."TEST_SEQ"  MINVALUE 1 MAXVALUE 9999999999999999999999999999 INCREMENT BY 1 START WITH 1 NOCACHE  ORDER  NOCYCLE ;
   
使用数据字典生成动态创建语句
可以使用user_sequences来构建动态的创建语句。
可以使用如下的脚本来实现。
set pages 0
set linesize 200
select 'create sequence '||sequence_name||   
       ' minvalue '||min_value||   
       ' maxvalue '||max_value||   
       ' start with '||last_number||   
       ' increment by '||increment_by||   
        (case when cache_size=0 then ' nocache' else ' cache '||cache_size end) ||';'  
from user_sequences ; 

脚本运行情况如下:
create sequence TEST_SEQ minvalue 1 maxvalue 9999999999999999999999999999 start with 1 increment by 1 nocache;
create sequence TEST_SEQ2 minvalue 1 maxvalue 9999999999999999999999999999 start with 1 increment by 1 nocache;
以上两种方法如果可以访问远环境的情况下是不错的选择。
如果当我们拿到一个dump的时候,没有权限访问源环境的时候,也是可以做点工作得到sequence的语句的。这是第三种方法。
可以使用strings来解析dump文件,然后简单的过滤就能生成sequence的语句。
一般来说我们使用exp做schema级别的数据导出的时候可以看到下面的日志。默认是会导出sequence的值的。
About to export specified users ...
. exporting pre-schema procedural objects and actions
. exporting foreign function library names for user N1 
. exporting PUBLIC type synonyms
. exporting private type synonyms
. exporting object type definitions for user N1 
About to export N1's objects ...
. exporting database links
. exporting sequence numbers
. exporting cluster definitions
. about to export N1's tables via Conventional Path ...

我们可以尝试解析dump文件,使用如下的方式,假设dump文件为a.dmp,就能够很轻松的得到sequence的值。
[ora11g@rac1 ~]$ strings a.dmp|grep "CREATE SEQUENCE"|awk '{print $0";"}'
CREATE SEQUENCE "TEST_SEQ2" MINVALUE 1 MAXVALUE 9999999999999999999999999999 INCREMENT BY 1 START WITH 1 NOCACHE ORDER CYCLE;
CREATE SEQUENCE "TEST_SEQ" MINVALUE 1 MAXVALUE 9999999999999999999999999999 INCREMENT BY 1 START WITH 1 NOCACHE NOORDER NOCYCLE;

总之办法总比困难多,还是有很多的途径来实现一些没有的功能。


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
开发指南—Sequence—显示用法—查询与获取Sequence
本文主要介绍如何查询Sequence类型以及获取Sequence值。
0 0
开发指南—Sequence—显示用法—创建Sequence
本文主要介绍如何创建各种类型的Sequence。
0 0
实战篇:LogMiner 分析数据泵导入参数 TABLE_EXISTS_ACTION 的秘密
前几天,技术交流群里看到大家讨论 Oracle 数据泵导入时使用 table_exists_action 参数,存在一些疑惑。于是,我打算通过 LogMiner 来分析一下在线重做日志,看看到底是怎么玩的。
0 0
聊聊Spring的bean覆盖(存在同名name/id问题),介绍Spring名称生成策略接口BeanNameGenerator【享学Spring】(中)
聊聊Spring的bean覆盖(存在同名name/id问题),介绍Spring名称生成策略接口BeanNameGenerator【享学Spring】(中)
0 0
oracle数据库imp导入失败提示:“不是有效的导出文件, 标头验证失败”解决方法,修改dmp文件里oracle数据库版本号方法
oracle数据库imp导入失败提示:“不是有效的导出文件, 标头验证失败”解决方法,修改dmp文件里oracle数据库版本号方法
0 0
plsql 导入导出表、数据、序列、视图
 一、导出: 1、打开plsql-->工具----》导出用户对象(可以导出表结构和序列、视图) ps:如果上面不选中"包括所有者",这样到导出的表结构等就不包含所有者, 这样就可以将A所有者的表结构等导入到B所有者的表空间中 2、导出表结构和表数据: 二、导入: 1、首先要创建用户和表空间 (1)创建用户: (2)创建表空间:电脑开始菜单-----》找到oracle目录
1581 0
使用导出导入(datapump)方式将普通表切换为分区表
      随着数据库数据量的不断增长,有些表需要由普通的堆表转换为分区表的模式。有几种不同的方法来对此进行操作,诸如导出表数据,然后创建分区表再导入数据到分区表;使用EXCHANGE PARTITION方式来转换为分区表以及使用DBMS_REDEFINITION来在线重定义分区表。
960 0
【导入导出】数据泵 job_name参数的使用
数据泵的工作流程如下:       (1)在命令行执行命令       (2)expdp/impd 命令调用DBMS_DATAPUMP PL/SQL包。 这个API提供高速的导出导入功能。
561 0
+关注
jeanron100
Oracle ACE,《Oracle DBA工作笔记》作者 现就职于国内某互联网公司,擅长数据管理,数据迁移,性能优化,目前专注于开源技术,运维自动化和性能优化。
文章
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载