1. 数据字典视图与动态性能视图
在Oracle数据库中,与用户相关的表可以分为三种类型:
- 用户自己创建的表:这些表由用户在数据库中自行创建,存储业务数据。
- 数据字典视图:由Oracle数据库自动生成的系统表,包含数据库结构、用户权限和数据库对象的定义信息。
- 动态性能视图:用于反映数据库运行期间产生的动态性能相关信息,由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工具的无限可能,让复杂的任务变得简单,让你的工作更加轻松和高效。