通过Oracle 9i的DBMS_METADATA包得到DLL语句

2016-02-19 18:32 3 1 收藏

只要你有一台电脑或者手机,都能关注图老师为大家精心推荐的通过Oracle 9i的DBMS_METADATA包得到DLL语句,手机电脑控们准备好了吗?一起看过来吧!

【 tulaoshi.com - 编程语言 】

  通过Oracle 9i的DBMS_METADATA包得到DLL语句

  基本上用到的语法如下:

  a.获取单个的建表和建索引的语法  

   setheadingoff;
  setechooff;
  setpages999;
  setlong90000;
  spooldept.sql
  selectdbms_metadata.get_ddl(table,dept,scott)fromdual;
  selectdbms_metadata.get_ddl(index,dept_idx,scott)fromdual;
  spooloff;

  b.获取一个schema下的任何建表和建索引的语法,以scott为例:

   setpagesize0
  setlong90000
  setfeedbackoff
  setechooff
  spoolscott_schema.sql
  connectscott/tiger;
  selectdbms_metadata.get_ddl(table,u.table_name)
  fromuser_tablesu;
  selectdbms_metadata.get_ddl(index,u.index_name)
  fromuser_indexesu;
  spooloff;

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

  c. 获取某个schema的建全部存储过程的语法  

   connectbrucelau/brucelau;
  spoolprocedures.sql
  select
  dbms_metadata.get_ddl(procedure,u.object_name)
  from
  user_objectsu
  where
  object_type=procedure;
  spooloff;

  另: 

  dbms_metadata.get_ddl(table,tab1,user1)

  三个参数中,第一个指定导出ddl定义的对象类型(此例中为表类型),第二个是对象名(此例中即表名),第三个是对象所在的用户名。

  从Oracle 9i开始Oracle提供了一个新的系统包DBMS_METADATA,可以用于提取对象创建的DDL语句。 

  这个Package功能极其强大,我们来看看它的使用方法.

  1.获得表的创建语句. 

  SQLdescdbms_metadataFUNCTIONADD_TRANSFORM.RETURNSNUMBER...FUNCTIONGET_DDLRETURNSCLOBArgumentNameTypeIn/OutDefault?
  OBJECT_TYPEVARCHAR2INNAMEVARCHAR2INSCHEMAVARCHAR2INDEFAULTVERSIONVARCHAR2INDEFAULTMODELVARCHAR2INDEFAULTTRANSFORM.VARCHAR2INDEFAULT....
  SQLsetlong2000
  SQLselectdbms_metadata.get_ddl('TABLE','TEST')fromdual;
  DBMS_METADATA.GET_DDL('TABLE','TEST')
  --------------------------------------------------------------------------------
  CREATETABLE"SYS"."TEST"
  ("OWNER"VARCHAR2(30),
  "OBJECT_NAME"VARCHAR2(128),
  "SUBOBJECT_NAME"VARCHAR2(30),
  "OBJECT_ID"NUMBER,
  "DATA_OBJECT_ID"NUMBER,
  "OBJECT_TYPE"VARCHAR2(18),
  "CREATED"DATE,
  "LAST_DDL_TIME"DATE,
  "TIMESTAMP"VARCHAR2(19),
  "STATUS"VARCHAR2(7),
  "TEMPORARY"VARCHAR2(1),
  "GENERATED"VARCHAR2(1),
  "SECONDARY"VARCHAR2(1)
  )PCTFREE10PCTUSED40INITRANS1MAXTRANS255NOCOMPRESSLOGGING
  STORAGE(INITIAL65536NEXT1048576MINEXTENTS1MAXEXTENTS2147483645
  PCTINCREASE0FREELISTS1FREELISTGROUPS1BUFFER_POOLDEFAULT)
  TABLESPACE"SYSTEM"
  SQL

  2.进一步的,可以通过dbms_metadata获得更全面的DDL语句

  Oracle提供一个全面的范例:  

   $ORACLE_HOME/rdbms/demo/mddemo.sql

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

  包括索引、授权、触发器等所有DDL语句都可以被提取。

  有兴趣的可以参考该文件,按照Demo的例子进行测试。

来源:https://www.tulaoshi.com/n/20160219/1618035.html

延伸阅读
Oracle 9i预定义的角色 表8.2 Oracle 9i预定义的角色 角色名称说明CONNECT数据库连接角色,用于连接数据库,具有创建簇、数据库链接、序列、同义词、表和视图,以及修改会话的权利DBA数据库管理员角色,具有所有使用ADMIN选项创建的系统权限,可以将系统权限授予其他用户或角色DELETE_CATALOG_ROLE删除目录角色,可以删除或重建数据字...
数据方案对象 表7.1 Oracle 9i的数据方案对象 名称含义数据表表是用于存放用户数据的数据库对象。数据库中的表按照功能的不同可以分为系统表和用户表两类。系统表用于存储管理用户数据和数据库本身的数据,又称数据字典表;用户表用于存放用户的数据信息,默认建立的数据表就是用户表索引索引就犹如一本书的目录,利用它可以快速找到...
Oracle 9i默认的用户 表8.1 Oracle 9i默认的主要用户 用户名口令登录身份及说明syschange_on_installSYSDBA或SYSOPER,但不能以NORMAL登录,可作为默认的系统管理员systemManagerSYSDBA或NORMAL,但不能以SYSOPER登录,可作为默认的系统管理员scottTigerNORMAL,普通用户aqadmaqadmSYSDBA或NORMAL,高级队列管理员。DbsnmpdbsnmpSYSDB...
3.3.1 用户 1. 用户密码 用户默认的密码为manager。 2. 用户权限 用户具有SYSDBA权限,即数据库管理员权限,包括。 打开数据库服务器 关闭数据库服务器 备份数据库 恢复数据库 日志归档 会话限制 管理功能 创建数据库 3.3.2 用户 1. 用户密码 用户默认的密码为change_on_install。...
我们都知道在9i之前,要想获得建表和索引的语句是一件很麻烦的事。我们通常的做法都是通过export with rows=no来得到,但它的输出因为格式的问题并不能直接拿来用。而另一种方法就是写复杂的脚本来查询数据字典,但这对于一稍微复杂的对象,如IOT和嵌套表等,还是无法查到。 从数据字典中获得DDL语句是经常要用的,特别是在...

经验教程

621

收藏

16
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部