首页 > 数据库 >Oracle-使用dbms_metadata.get_ddl()获取对象的定义

Oracle-使用dbms_metadata.get_ddl()获取对象的定义

时间:2024-01-09 17:01:02浏览次数:53  
标签:dbms set get DDL ddl metadata

dbms_metadata.get_ddl()用于获取对象的ddl,其具体用法如下。

注意:在sqlplus里,为了更好的展示DDL,需要设置如下参数:

set line 200
set pagesize 0
set long 99999
set feedback off
set echo off

1)获得表、索引、视图、存储过程、函数的DDL

select dbms_metadata.get_ddl('TABLE','TABLE_NAME','TABLE_OWNER') from dual;
select dbms_metadata.get_ddl('INDEX','INDEX_NAME','INDEX_OWNER') from dual;
select dbms_metadata.get_ddl('VIEW','VIEW_NAME','VIEW_OWNER') from dual;
select dbms_metadata.get_ddl('PROCEDURE','PROCEDURE_NAME','PROCEDURE_OWNER') from dual;
select dbms_metadata.get_ddl('FUNCTION','FUNCTION_NAME','FUNCTION_OWNER') from dual;

下面的脚本用于获得某个schema下所有的表、索引、视图、存储过程、函数的DDL

set pagesize 0
set long 90000
set feedback off
set echo off
spool schema_ddl.sql
SELECT DBMS_METADATA.GET_DDL('TABLE',u.table_name,u.owner) FROM DBA_TABLES u;
SELECT DBMS_METADATA.GET_DDL('VIEW',u.view_name,u.owner) FROM DBA_VIEWS u;
SELECT DBMS_METADATA.GET_DDL('INDEX',u.index_name,u.owner) FROM DBA_INDEXES u;
select dbms_metadata.get_ddl('PROCEDURE',u.object_name, u.owner,) from dba_objects u where u.object_type = 'PROCEDURE';
select dbms_metadata.get_ddl('FUNCTION',u.object_name, u.owner,) from dba_objects u where u.object_type = 'FUNCTION';
spool off;

2)获得表空间的DDL

获得单个表空间的DDL:

select dbms_metadata.get_ddl('TABLESPACE','TBS_NAME') 
from dual;

获得所有表空间的DDL:

SELECT DBMS_METADATA.GET_DDL('TABLESPACE', TS.tablespace_name) 
FROM DBA_TABLESPACES TS;

3)获得用户的DDL

获得单个用户的DDL:

select dbms_metadata.get_ddl('USER','EPAY_USER') 
from dual;

4)获得所有用户的DDL

SELECT DBMS_METADATA.GET_DDL('USER',U.username)
FROM DBA_USERS U;

例如:

su - oracle
sqlplus / as sysdba
set line 200
set pagesize 0
set long 99999
set feedback off
set echo off
select dbms_metadata.get_ddl('PROCEDURE','db1','check') from dual;

标签:dbms,set,get,DDL,ddl,metadata
From: https://blog.51cto.com/baoyw/9163385

相关文章

  • 使用bash脚本在Linux中发送HTTP GET请求
    在Linux中,使用bash脚本发送HTTPGET请求是一种常见的自动化任务。下面是一个简单的bash脚本示例,用于发送HTTPGET请求并处理响应:bash复制代码#!/bin/bash#定义URLurl="http://example.com" #发送GET请求并获取响应response=$(curl-s"$url")#检查响应状态码if [$?-eq......
  • 无涯教程-Redis - HGET命令函数
    RedisHGET命令用于获取与存储在键(key)处的字段关联的值。HGET-返回值返回与字段关联的值,不存在该字段或键不存在时返回空。HGET-语法以下是RedisHGET命令的基本语法。redis127.0.0.1:6379>HGETKEY_NAMEFIELD_NAMEHGET-示例redis127.0.0.1:6379>HSETm......
  • c# 类重写Equal,GetHashCode,实现IComparable,IComparable<T>
    ///<summary>///Array,List<T>排序都依赖于IComparable///</summary>publicclassStudent:IEquatable<Student>,IComparable,IComparable<Student>{publicintId{get;set;}publicstringName{get;......
  • 无涯教程-Redis - GETBIT 命令函数
    RedisGETBIT命令用于获取存储在键(key)处的字符串值中偏移量的位值。GETBIT-返回值整数,存储在偏移量处的位值。GETBIT-语法以下是RedisGETBIT命令的基本语法。redis127.0.0.1:6379>GETBITKEY_NAMEOFFSETGETBIT-示例redis127.0.0.1:6379>SETBITmykey7......
  • 无涯教程-Redis - GETSET 命令函数
    RedisGETSET命令在Redis键中设置指定的字符串值并返回其旧值。GETSET-返回值简单的字符串回复,键的旧值,如果键不存在,则返回nil。GETSET-语法以下是RedisGETSET命令的基本语法。redis127.0.0.1:6379>GETSETKEY_NAMEVALUEGETSET-示例redis127.0.0.1:6379>G......
  • python flask get请求接收参数
    前言全局说明pythonflaskget请求接收参数一、安装flsas模块官方源:pip3installflask国内源:pip3installflask-ihttp://pypi.douban.com/simple/--trusted-hostpypi.douban.com以上二选一,哪个安装快用哪个二、引用模块fromflaskimportFlask,request......
  • 无涯教程-Redis - GETRANGE 命令函数
    RedisGETRANGE命令用于获取键处存储的字符串值的子字符串,该子字符串由偏移量start和end(包括两端)确定,可以使用负偏移量来提供从字符串末尾开始的偏移量。GETRANGE-返回值简单的字符串回复。GETRANGE-语法以下是RedisGETRANGE命令的基本语法。redis127.0.0.1:637......
  • 无涯教程-Redis - GET 命令函数
    RedisGET命令用于获取存储在指定键中的值,如果键不存在,则返回nil,如果返回的值不是字符串,则返回错误。GET-返回值简单的字符串回复。值或键或无。GET-语法以下是RedisGET命令的基本语法。redis127.0.0.1:6379>GETKEY_NAMEGET-示例首先,在Redis中设置一个键(ke......
  • Python flask 网页版执行shell命令并返回结果['GET', 'POST'] 混合方式
    前言全局说明Pythonflask网页版执行shell命令并返回结果一、需要安装的库pip3installflask-ihttp://pypi.douban.com/simple/--trusted-hostpypi.douban.compip3installsubprocess-ihttp://pypi.douban.com/simple/--trusted-hostpypi.douban.com二、inde......
  • 关于腾讯地图geolocation.getLocation 经常定位失败,定位时间过长的解决方法
    今天遇到个项目,腾讯地图定位出现问题,导致地图无法呈现出最近的目标 这是正常的效果,之前一直出现贵州等地点的信息,查看控制台的网络后,发现腾讯的定位失败,要么就是定位时间过长,要20S左右,但是换EDGE浏览器却能正常加载,除了EDGE浏览器都会出现这个问题。随后我去查阅腾讯地图接口......