一、获取数据库对象(Oracle、达梦)

  • 以下方式在达梦DM数据库中都能跑通,Oracle未测试所有的方式。

1、获取所有对象——所有模式下的

  • 数据库所有对象表:包括表、视图、物化视图、函数、存储过程……等

①、ALL_OBJECTS视图方式

-- 查询所有对象
SELECT * from ALL_OBJECTS
-- 筛选条件 - OWENR:哪个数据库。- OBJECT_TYPE 类型:
SELECT OBJECT_NAME,OBJECT_TYPE from ALL_OBJECTS
WHERE OWNER = 'MIDDLE' AND OBJECT_TYPE = 'MATERIALIZED VIEW'

OBJECT_TYPE解释:

  • oracle的ALL_OBJECTS中的OBJECT_TYPE表示:
  1. TABLE:表示表,这是用于存储和管理数据库中数据的主要结构。
  2. VIEW:表示视图,它是一个虚拟表,基于一个或多个表的列的查询结果生成。
  3. PROCEDURE:表示存储过程,它是一组预编译的SQL语句,用于执行特定的操作或逻辑。
  4. SEQUENCE:表示序列,它是一个数据库对象,用于生成唯一的序列号。
  5. INDEX:表示索引,它可以帮助提高查询的性能,通过创建单独的表来存储查询中使用的列的值。
  6. MATERIALIZED VIEW:表示物化视图,它是基于一个或多个表的查询结果预先计算并存储的视图。
  7. JAVA SOURCE:表示Java源代码,这是存储在数据库中的Java类或接口的源代码。
  8. JAVA CLASS:表示Java类,这是编译后的Java类,存储在数据库中。
  9. JAVA RESOURCE:表示Java资源,这可以是任何类型的资源,如属性文件、文本文件等。
  10. JAVA DATA:表示Java数据对象,这是存储在数据库中的Java对象。
  11. XML TABLE:表示XML表,这是将XML文档作为表进行存储和处理的方式。
  12. TYPE:表示自定义类型,这是用户定义的数据类型。
  13. PACKAGE:表示包,这是用于封装和组织相关过程和类型的逻辑单元。
  14. JAVA RESOURCE:表示Java资源,这可以是从文件中导入的任何类型的资源。
  15. DATA FILE:表示数据文件,这是存储数据库数据的物理文件。
  16. FUNCTION:函数。
  • 达梦的ALL_OBJECTS中的OBJECT_TYPE表示:
  1. TABLE:表示表,这是用于存储和管理数据库中数据的主要结构。
  2. VIEW:表示视图,它是一个虚拟表,基于一个或多个表的列的查询结果生成。
  3. PROCEDURE:表示存储过程,它是一组预编译的SQL语句,用于执行特定的操作或逻辑。
  4. FUNCTION:表示函数,它是一组可调用的代码块,用于执行特定的操作或计算结果。
  5. SEQUENCE:表示序列,它是一个数据库对象,用于生成唯一的序列号。
  6. INDEX:表示索引,它可以帮助提高查询的性能,通过创建单独的表来存储查询中使用的列的值。
  7. MATERIALIZED VIEW:表示物化视图,它是基于一个或多个表的查询结果预先计算并存储的视图。
  8. PACKAGE:表示包,这是用于封装和组织相关过程和类型的逻辑单元。
  9. TYPE:表示自定义类型,这是用户定义的数据类型。

②获取所有对象的其他方式

-- 方式1---------------------
select * from DBA_OBJECTS where OWNER = 'APP1'; -- 方式2---------------------
-- 不能区分:函数、存储过程
select * from SYS.SYSOBJECTS where SCHID = '150996004'; -- 方式3---------------------
select * from ALL_OBJECTS where owner = 'APP1';

2、获取所有对象——当前登陆模式下的

  • 就是把前面的ALL,改成USER
  • 如果只查询登陆模式下的对象,建议这种方式
SELECT * FROM USER_OBJECTS;

3、获取其他对象

  • ps:包括所有模式、当前模式。当前模式一般是把all换成user

3.1、表

-- 获取表——所有模式
select * from all_tables;
-- 获取表——当前登陆模式
select * from user_tables;

3.2、字段

  • 包括表、视图、物化视图的字段
-- 获取所有模式下的所有字段,where可以指定模式
select * from all_tab_columns where owner = 'APP1';
-- 获取当前登陆模式的字段
select * from user_tab_columns;

3.3、视图

-- 获取视图——所有模式
select * from all_views;
-- 获取视图——当前登陆模式
select * from user_views;

3.4、索引

-- 获取索引——所有模式
select * from all_indexes where owner = 'APP1';
-- 获取索引——当前登陆模式
select * from user_indexes;
  • 获取索引列——索引指定的列
-- 获取索引列——所有模式
select * from all_ind_columns where index_owner = 'APP1';
-- 获取索引列——当前登陆模式
select * from user_ind_columns;
-- 获取当前登陆模式下的索引列——按索引名字去重并统计数量
select count(DISTINCT INDEX_NAME) from user_ind_columns;

3.5、约束——包括主键、外键

  • CONSTRAINT_TYPE:P:主键、R:外键
  • 约束还包括:检查……等
-- 获取约束——所有模式
select * from all_constraints where owner = 'APP1';
-- 获取约束——当前登陆模式
select * from user_constraints;
  • 查询约束所在的列
-- 查询约束列(列上有约束)——所有模式
select * from all_cons_columns where owner = 'APP1';
-- 查询约束列(列上有约束)——当前登陆模式
select * from user_cons_columns;

3.6、物化视图——Oracle

  • 也可以使用《一》中的ALL_OBJECTS进行查询
-- 整个数据库的物化视图
select * from DBA_MVIEWS where OWNER = 'MIDDLE' -- 当前用户的物化视图
SELECT * FROM USER_MVIEWS WHERE MVIEW_NAME = 'V2' -- 创建物化日志
create materialized view log on "Z_ZZX" with rowid, sequence (ID_CPM_JH, CODE) including new values; -- 查询物化视图的日志
select * from MLOG$_Z_ZZX -- 查询物化视图日志表
SELECT * from ALL_OBJECTS WHERE OWNER = 'MIDDLE' and OBJECT_NAME LIKE '%MLOG$%' -- 查询物化视图
SELECT * from ALL_OBJECTS
WHERE OWNER = 'MIDDLE' AND OBJECT_TYPE = 'MATERIALIZED VIEW' -- 查询物化视图需要的表
select REFERENCED_NAME from ALL_DEPENDENCIES WHERE OWNER = 'MIDDLE' AND TYPE = 'MATERIALIZED VIEW' AND NAME = 'WH_LOG' AND REFERENCED_NAME <> 'WH_LOG' -- 连表查询物化视图以及使用到的表
SELECT * FROM user_mviews um left join SYS.ALL_DEPENDENCIES ad on ad.NAME = um.MVIEW_NAME WHERE ad.OWNER = 'MIDDLE' AND ad.TYPE = 'MATERIALIZED VIEW' AND ad.NAME = 'WH_LOG' AND ad.REFERENCED_NAME <> 'WH_LOG'

二、获取对象的DDL-数据定义语言(达梦)

  • 语法:SELECT dbms_metadata.get_ddl('对象类型','对象名称') FROM DUAL
  • 对象类型见:类型(OBJECT_TYPE)达梦
-- 获取DDL语句(根据不同类型)
SELECT dbms_metadata.get_ddl('MATERIALIZED_VIEW','WH_LOG') FROM DUAL -- 获取DDL-物化视图日志
SELECT dbms_metadata.get_ddl('TABLE','MLOG$_Z_ZZX') FROM DUAL
-- 获取DDL-物化视图
SELECT dbms_metadata.get_ddl('MATERIALIZED_VIEW','CS_COMMIT_COMPLETE') FROM DUAL
SELECT dbms_metadata.get_ddl('MATERIALIZED_VIEW_LOG','MLOG$_Z_ZZX') FROM DUAL -- 获取DDL-视图
SELECT dbms_metadata.get_ddl('VIEW','V1') FROM DUAL

…… 还可以获取建表等的语句。

Oracle、达梦:☆获取数据库对象、获取对象的DDL定义语句(达梦)的更多相关文章

  1. Oracle获取数据库中的对象创建语句

    使用dbms_metadata.get_ddl()函数可以做到. 实验环境:Oracle 11.2.0.4 以获取jingyu用户下的T1表为例: SQL> conn jingyu/jingyu ...

  2. oracle查询在当前数据库下当前用户拥有的表语句

    1.查询表的数目: select count(*) from tabs select count(*) from user_tables 2.查询用户拥有哪些表: select * from tabs ...

  3. MySQL提供了以下三种方法用于获取数据库对象的元数据

    MySQL提供了以下三种方法用于获取数据库对象的元数据: 1)show语句 2)从INFORMATION_SCHEMA数据库里查询相关表 3)命令行程序,如mysqlshow, mysqldump 用 ...

  4. Android 获取对象列表中的某一列 / 所有对象的某一字段,Realm数据库可获取某一字段所有值

    现在项目用的数据库是Realm,所以想要获取数据库中某一字段的数据没有一句直接的语句进行获取,就像MySQL一样的select name from User,从User表里获取所有的name. 所以只 ...

  5. EChart系列:在echart3中使用百度地图扩展之后,如何获取到百度地图对象

    最近做项目想要在百度地图上叠加显示echart的散点图,然后根据地图的缩放等级和区域范围要显示不同的散点图,这中间折腾了好久.功能要求包括: (1)底图使用百度地图: (2)可以在地图上叠加显示ech ...

  6. 获取$(this)子节点对象的方法

    获取$(this)子节点对象的方法: 1.children()方法: children() 方法返回被选元素的所有直接子元素. 该方法只会向下一级对 DOM 树进行遍历. 2.find()方法: fi ...

  7. MVC-通过对象获取整个表单内容

    -------- 在MVC的Controller(控制器)里面定义相同的方法时,我们需要解决重载问题: 解决方案一:在参数中定义一个FormCollection类型,解决问题 [HttpSet] pu ...

  8. resultset 对象获取行字段数据时报:java.sql.SQLException: Column 'id' not found.

    resultset 对象获取行字段数据时报:java.sql.SQLException: Column 'id' not found. 代码: String sql="SELECT d.co ...

  9. javascript获取iframe框架中页面document对象,获取子页面里面的内容,iframe获取父页面的元素,

    javascript获取iframe框架中,加载的页面document对象 因为浏览器安全限制,对跨域访问的页面,其document对象无法读取.设置属性 function getDocument(i ...

  10. 快捷获取浏览器(navigator对象)的全部属性

    理论:     navigator对象包含关于web浏览器的信息,浏览器的类型,版本信息都可以从该对象获取. 属性 说明 appCodeName 浏览器代码说明 appName 浏览器名称 appVe ...

随机推荐

  1. kingbaseES 优化之数据库瓶颈排查

    针对数据库的性能瓶颈排查方法分为两个层次1.实例级别性能问题排查 2.语句级别性能问题排查 实例级别 实例级别性能问题排查用来分析数据库实例整体是否存在性能瓶颈,然后根据排除出的疑似问题进行实例级别参 ...

  2. KingbaseES例程_普通表在线转分区表(基于规则)

    KingbaseES例程_普通表在线转分区表 概述 普通表转分区表,使用视图的替换式规则,以路由方式,实现在线转移数据. 数据准备 /*普通大表*/ create table tab_single a ...

  3. 如何拿到接口返回的消耗token

    SemanticKernel 以下引用自官方案例 Text模型 使用Kernel FunctionResult functionResult = await kernel.InvokePromptAs ...

  4. Csharp线程

    CSharpe线程 目录 CSharpe线程 C#如何操作线程 Thread 1. Thread如何开启一个线程呢? 2. Thread中常见的API 3. thread的扩展封装 threadpoo ...

  5. #裴蜀定理#CF7C Line

    题目 给定三个整数\(a,b,c\),问是否能找到两个数\(x,y\)使得\(ax+by+c=0\),没有则输出-1 分析 先把式子转换成\(ax+by=-c\) 然后\(x,y\)是整数当且仅当\( ...

  6. #线段树,离散#nssl 1476 联

    分析 由于下标过大,考虑离散,不仅仅是区间左右端点 假设只有一个区间从1到\(x\),那么修改后答案应该是\(x+1\) 所以说还要记录右端点+1的位置,你以为这就能A了吗 为了避免标记被覆盖,无论是 ...

  7. 一个库帮你快速实现EF Core数据仓储模式

    前言 EF Core是我们.NET日常开发中比较常用的ORM框架,今天大姚要分享的内容是如何使用EF Core Generic Repository通用仓储库来快速实现EF Core数据仓储模式. E ...

  8. VS2019快捷键

    快捷键功能CTRL + SHIFT + B生成解决方案CTRL + F7 生成编译CTRL + O 打开文件CTRL + SHIFT + O打开项目CTRL + SHIFT + C显示类视图窗口F4 ...

  9. MogDB/openGauss访问控制简介

    MogDB/openGauss 访问控制简介 SQL 可以针对不同的数据库对象赋予不同的权限,这样就可以限制用户对数据的不必要访问,提高数据访问的安全性.常见的 SQL 权限如下: SELECT/UP ...

  10. SpringCloud整体架构概览

    什么是SpringCloud #目标 协调任何服务,简化分布式系统开发. #简介 构建分布式系统不应该是复杂的,SpringCloud对常见的分布式系统模式提供了简单易用的编程模型,帮助开发者构建弹性 ...