网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.为ORACLE 8i for SOLARIS配置并管.
.自定义临时表实现及在Oracle Spa.
.关于分布式oracle中database lin.
.ORACLE 9.2.0.5 PATCHES FOR .
.Oracle9i 数据库管理实务讲座(七).
.外部程序使一切变得简单.
.建立虚拟记忆体.
.如何导入指定表.
.DBA的工作列表上写了些什么.
.oralce在红旗linux上的简单安装.
.解读ORACLE数据库的统一命名与编.
.分享Oracle9i中建立自增字段的最.
.Oracle 9i 分析函数参考手册.
.两小时搞定RHAS 3.0上的Oracle 9.
.怎样做8i完全(备份)与完全(恢.
.在ORACLE里设置访问多个SQL Serv.
.Oracle Database与Oracle Instan.
.Oracle 10g Installer 创建临时文.
.如何通过DB link进行远程过程或函.
.为最佳性能而调优 Red Hat(4).

Oracle 9i新特性研究系列之二 -- 轻松取得建表和索引的DDL语句

发表日期:2008-2-9



  我们都知道在9i之前,要想获得建表和索引的语句是一件很麻烦的事。我们可以通过eXPort with rows=no来得到,但它的输出因为格式的问题并不能直接拿来用。而另一种方法就是写复杂的脚本来查询数据字典,但这对于一稍微复杂的对象,如IOT和嵌套表等,还是无法查到。
  
  从数据字典中获得DDL语句是经常要用的,非凡是在系统升级/重建的时候。在Oracle 9i中,我们可以直接通过执行dbms_metadata从数据字典中查处DDL语句。使用这个功能强大的工具,我们可以获得单个对象或整个SCHEMA的DDL语句。最好不过的是因为它使用起来很简单。
  
  1、获得单个表和索引DDL语句的方法:
  
  -----------------------------------------------------------------------
  
  set heading off;
  
  set echo off;
  
  Set pages 999;
  
  set long 90000;
  
   
  
  spool get_single.sql
  
  select dbms_metadata.get_ddl('TABLE','SZT_PQSO2','SHQSYS') from dual;
  
  select dbms_metadata.get_ddl('INDEX','INDXX_PQZJYW','SHQSYS') from dual;
  
  spool off;
  
  -----------------------------------------------------------------------
  
  下面是输出。我们只要把建表/索引语句取出来在后面加个分号就可以直接运行了。
  
  -----------------------------------------------------------------------
  
  SQL> select dbms_metadata.get_ddl('TABLE','SZT_PQSO2','SHQSYS') from dual;
  
   
  
  CREATE TABLE "SHQSYS"."SZT_PQSO2"
  
  ( "PQBH" VARCHAR2(32) NOT NULL ENABLE,
  
  "ZJYW" NUMBER(10,0),
  
  "CGSO" NUMBER(10,0) NOT NULL ENABLE,
  
  "SOLS" VARCHAR2(17),
  
  "SORQ" VARCHAR2(8),
  
  "SOWR" VARCHAR2(8),
  
  "SOCL" VARCHAR2(6),
  
  "YWHM" VARCHAR2(10),
  
  "YWLX" VARCHAR2(6)
  
  ) PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING
  
  STORAGE(INITIAL 1048576 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645
  
  PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT)
  
  TABLESPACE "DATA1"
  
   
  
   
  
  SQL> select dbms_metadata.get_ddl('INDEX','INDXX_PQZJYW','SHQSYS') from dual;
  
   
  
  CREATE INDEX "SHQSYS"."INDXX_PQZJYW" ON "SHQSYS"."SZT_PQSO2" ("ZJYW")
  
  PCTFREE 10 INITRANS 2 MAXTRANS 255
  
  STORAGE(INITIAL 1048576 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645
  
  PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT)
  
  TABLESPACE "DATA1"
  
   
  
   
  
  SQL>
  
  SQL> spool off;
  
  -----------------------------------------------------------------------
  
  2、获得整个SCHEMA DDL语句的方法:
  
  -----------------------------------------------------------------------
  
  set pagesize 0
  
  set long 90000
  
  set feedback off
  
  set echo off
  
  spool get_schema.sql
  
  connect shqsys/shqsys@hawk1;
  
  SELECT DBMS_METADATA.GET_DDL('TABLE',u.table_name)
  
  FROM USER_TABLES u;
  
  SELECT DBMS_METADATA.GET_DDL('INDEX',u.index_name)
  
  FROM USER_INDEXES u;
  
  spool off;
  
  -----------------------------------------------------------------------
  
  需要注重的是,当我们的表中有外健(参照约束)时,我们需要判别参照表之间的顺序,确保重建时按照合理的顺序进行。
你可以通过查询dba_constraints and dba_cons_columns来确定各表之间的顺序,不再详述。
上一篇:Oracle数据分片技术 人气:530
下一篇:Oracle 9i新特性研究系列之三 -- 撤销段的自动管理 人气:553
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐