数据库管理必读:Oracle数据字典视图与动态性能视图

在这里插入图片描述

1. 数据字典视图与动态性能视图

在Oracle数据库中,与用户相关的表可以分为三种类型:

  1. 用户自己创建的表:这些表由用户在数据库中自行创建,存储业务数据。
  2. 数据字典视图:由Oracle数据库自动生成的系统表,包含数据库结构、用户权限和数据库对象的定义信息。
  3. 动态性能视图:用于反映数据库运行期间产生的动态性能相关信息,由SGA(System Global Area,系统全局区)或控制文件中的信息生成。

2. 数据字典视图

数据字典视图是一个静态的、由Oracle自动生成和维护的系统表。数据字典视图存储了关于数据库本身的重要信息,这些信息包括:

  • 数据库的物理结构和逻辑结构信息:如表空间、段、区等。
  • 用户和权限信息:包括用户的角色和授权。
  • 数据库对象的信息:如表、视图、索引、存储过程、约束等。
  • 审计信息:记录与安全相关的操作和事件。

数据字典视图的特点

  • 这些信息在数据库安装后立即生成,随着时间的推移不断更新。
  • 数据字典视图的信息主要是静态的,不会随着数据库的关闭而消失。
  • 这些信息一般只为Oracle数据库内部使用,主要由DBA和有特殊权限的用户来查看和维护。

数据字典视图的用途

  • 数据字典视图为用户提供了数据库的基础信息,方便用户查看和管理数据库对象。
  • 用户可以通过查询这些视图来获取数据库的结构、对象定义等信息,使用SQL*Plus执行DESC命令可以查看表结构。

3. 动态性能视图

动态性能视图(Dynamic Performance Views),通常以v$开头,用于监控和调优数据库的性能。它们主要包含以下信息:

  • 数据库实例的当前运行状态:这些信息动态反映数据库实例的实际运行情况,信息源自SGA或控制文件。
  • 这些视图的内容会随着实例的启动、运行和关闭而变化。

动态性能视图的特点

  • 这些视图信息是动态生成的,不同于数据字典视图的静态性质。
  • 信息存储在SGA或控制文件中,随实例运行动态变化。

动态性能视图的用途

  • DBA们可以通过这些视图监控数据库的运行状况,获取性能统计信息,用于数据库的优化调优。

4. 数据字典视图与动态性能视图的实际操作

数据字典视图的使用示例

  • 查询当前用户所有对象的信息:
    SELECT object_name, object_type, created, status FROM user_objects;
    
  • 查询当前用户所有表的信息:
    SELECT table_name, tablespace_name FROM user_tables;
    

动态性能视图的使用示例

  • 查询数据库中的等待事件信息:
    SELECT event, total_waits, time_waited, average_wait FROM v$SYSTEM_event;
    
  • 查询SGA中各内存区域的大小:
    SELECT name, round(bytes/1024/1024, 0) as MB FROM v$sgastat WHERE round(bytes/1024/1024, 0) > 0;
    

5. 数据字典视图的类别

数据字典视图可以按访问权限和作用范围分为几类,主要包括:

  • user_开头的视图:存储当前用户所拥有的对象信息。
  • all_开头的视图:存储当前用户有权访问的对象信息。
  • dba_开头的视图:存储数据库中所有对象的信息,这类视图通常只能由DBA用户访问。

6. 动态性能视图的名称规则

动态性能视图通常以v$开头,常用的视图有:

  • v$SYSTEM_event:用于查询系统等待事件。
  • v$sgastat:用于查询SGA中各个组件的大小。

7. 动态性能视图的使用

SQL示例

  • 查询数据库等待事件信息:
    SELECT event, total_waits, time_waited, average_wait FROM v$SYSTEM_event;
    
  • 查询SGA中各缓冲区的大小:
    SELECT name, round(bytes/1024/1024, 0) as MB FROM v$sgastat WHERE round(bytes/1024/1024, 0) > 0;
    

数据字典视图提供了数据库的基础信息,而动态性能视图则提供了数据库运行期间的动态性能数据。这两类视图是DBA管理、监控和优化数据库的重要工具。

数据字典视图与动态性能视图的实际操作

1、 数据字典视图的使用示例

  • 查询当前用户所有对象的信息:
    SELECT object_name, object_type, created, status FROM user_objects;
    
  • 查询当前用户所有表的信息:
    SELECT table_name, tablespace_name FROM user_tables;
    

2、动态性能视图的使用示例

  • 查询数据库中的等待事件信息:
    SELECT event, total_waits, time_waited, average_wait FROM v$SYSTEM_event;
    
  • 查询SGA中各内存区域的大小:
    SELECT name, round(bytes/1024/1024, 0) as MB FROM v$sgastat WHERE round(bytes/1024/1024, 0) > 0;
    

3、动态性能视图的使用

SQL示例

  • 查询数据库等待事件信息:
    SELECT event, total_waits, time_waited, average_wait FROM v$SYSTEM_event;
    
  • 查询SGA中各缓冲区的大小:
    SELECT name, round(bytes/1024/1024, 0) as MB FROM v$sgastat WHERE round(bytes/1024/1024, 0) > 0;
    

非常感谢您读到这里!如果您觉得这篇文章对您有帮助,可以关注一下博主。关注后,您将第一时间获得最新的AI、云计算、运维(Linux、数据库,容器等)技术,以及更多实用的技能干货。

让AI工具成为你的得力助手,感受AI工具的无限可能,让复杂的任务变得简单,让你的工作更加轻松和高效。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

周同学的技术栈

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值