dbms_metadata.get_ddl的使用总结

php中文网
发布: 2016-06-07 15:58:01
原创
1871人浏览过

dbms_metadata.get_ddl的使用总结(转载) 在日常工作中,经常有人通过工具去查看对象的定义,其实有时候这样去查看也很烦的。在工作中,也有同事问我怎么获取对象定义,今天我做个总结给大家,希望对大家有所帮助!

dbms_metadata.get_ddl的使用总结(转载)

在日常工作中,经常有人通过工具去查看对象的定义,其实有时候这样去查看也很烦的。在工作中,也有同事问我怎么获取对象定义,今天我做个总结给大家,希望对大家有所帮助!

获取对象定义的包为:dbms_metadata,其中的get_ddl函数是获取对象的函数

get_ddl函数返回创建对象的原数据的ddl语句,参数说明

1、object_type ---需要返回原数据的ddl语句的对象类型
2、name --- 对象名称
3、schema ---对象所在的schema,默认为当前用户所在所schema
4、version ---对象原数据的版本
5、model ---原数据的类型默认为oracle
6、transform. - xsl-t transform. to be applied.
7、returns: 对象的原数据默认以clob类型返回

其中,我们经常用到的是前三项。

dbms_metadata包中的get_ddl函数定义:

function get_ddl ( object_type in varchar2,
name in varchar2,
schema in varchar2 default null,
version in varchar2 default 'compatible',
model in varchar2 default 'oracle',
transform. in varchar2 default 'ddl') return clob;

注意:

1、如果使用sqlplus需要进行下列格式化,特别需要对long进行设置,否则无法显示完整的sql
2、参数要使用大写,否则会查不到

set linesize 180
set pages 999
set long 90000

1、查看数据库表的定义写法:

select dbms_metadata.get_ddl('table','tablename','username') from dual;

2、查看索引的sql

select dbms_metadata.get_ddl('index','indexname','username') from dual;

3、查看创建主键的sql

select dbms_metadata.get_ddl('constraint','constraintname','username') from dual;

4、查看创建外键的sql

select dbms_metadata.get_ddl('ref_constraint','ref_constraintname','username') from dual;

5、查看创建视图的sql

select dbms_metadata.get_ddl('view','viewname','username') from dual;

6、查看用户的sql

select dbms_metadata.get_ddl('user','username') from dual;

7、查看角色的sql

select dbms_metadata.get_ddl('role','rolename') from dual;

8、查看表空间的sql

select dbms_metadata.get_ddl('tablespace','tablespacename') from dual;

9、获取物化视图sql

select dbms_metadata.get_ddl('materialized view','mvname') from dual;

10、获取远程连接定义sql

select dbms_metadata.get_ddl('db_link','dblinkname','username') stmt from dual

11、获取用户下的触发器sql

select dbms_metadata.get_ddl('trigger','triggername','username) from dual;

12、获取用户下的序列

select dbms_metadata.get_ddl('sequence','sequencename') from dual;

13、获取用户下的函数

select dbms_metadata.get_ddl('function','functionname','username') from dual

14、获取包的定义

select dbms_metadata.get_ddl('package','packagename','username') from dual

15、获取存储过程

select dbms_metadata.get_ddl('procedure','procedurename','username') from dual

16、获取包体定义

select dbms_metadata.get_ddl('package body','packagebodyname','username') from dual

17、获取远程数据库对象的定义

select dbms_lob.substr@dblinkname(dbms_metadata.get_ddl@dblinkname('table', 'tablename', 'username')) from dual@dblinkname

18、获取多个对象的定义

select dbms_metadata.get_ddl(o.object_type, o.object_name,o.owner)
from dba_objects o
where o.object_type in ('table','index','procedure','function') and onwer = 'onwername';

这个语句可以更改一下,就可以得到很多语句出来

19、常见错误
sql> select dbms_metadata.get_ddl('table','tablename','username') from dual;
error:
ora-19206: invalid value for query or ref cursor parameter
ora-06512: at "sys.dbms_xmlgen", line 83
ora-06512: at "sys.dbms_metadata", line 345
ora-06512: at "sys.dbms_metadata", line 410
ora-06512: at "sys.dbms_metadata", line 449
ora-06512: at "sys.dbms_metadata", line 615
ora-06512: at "sys.dbms_metadata", line 1221
ora-06512: at line 1
no rows selected
解决办法:运行 $oracle_home/rdbms/admin/catmeta.sql

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号