数据库数据字典与动态性能视图

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:
一 动态性能视图v$开头,所有者为sys,只能有DBA查询。启动数据库时自动创建,关闭数据库时,自动被删除。
 
常用动态性能视图表

序号
文件名
含义
1
v$database
当前数据库
2
v$instance
获取当前实例详细信息
3
v$controlfile
控制文件
4
v$datafile
数据文件
5
v$dbfile
数据文件编号和名称
6
v$log
日志组
7
v$logfile
日志组成员(日志文件)
8
v$sga
系统全局区
9
V$sgainfo
获取sga更详细信息
10
v$parameter
参数文件(初始化参数)
11
v$version
Oracle版本
12
v$session
会话
13
v$process
Oracle进程
14
v$bgprocess
Oracle后台进程
15
v$tablespace
表空间
16
v$tempfile
当前数据库所包含的临时文件
17
v$locked_object
显示被加锁的数据对象
18
v$lock
显示锁信息
19
v$fixed_table
显示所有可用的动态性能视图及动态性能表

 
1、当前使用的数据库名称及创建日期(设置屏幕显示的列宽)
        首先查看结构     desc v$database
        然后查询  select name,created from v$database;
2、查看数据库的启动实例
        首先查看结构     desc v$instance
        然后查询      select INSTANCE_NAME from v$instance;
3、查看物理结构
     1)查看控制文件位置及名称
       首先查看结构     desc v$controlfile
       然后查询    select name from v$controlfile;
     2)查看数据文件位置及名称
       两种方法:⑴首先查看结构 desc v$dbfile (只能查找文件的名称和位置)
然后查询 col name format a60;(调整显示的行宽)
                 select * from v$dbfile;
⑵首先查看结构     desc v$datafile
                  然后查  select name from v$datafile;
       查看临时文件
         首先查看结构  desc v$tempfile
         然后查询  select NAME from v$tempfile;
(3)查看日志组的个数、每个日志组的成员个数及日志成员大小
       首先查看结构     desc v$log
       然后查询  select group#,members,bytes from v$log;
(4)查看日志文件隶属的日志组及日志文件大小
       首先查看结构     desc v$logfile
       然后查询  select group#,members,bytes from v$logfile;
4、查看对应的表空间
        首先查看结构     desc v$tablespace
        然后查询    select name from v$tablespace;
5、查看系统默认分配的内存状况
        首先查看结构     desc v$sga
        然后查询  select * from v$sga;
      查详细信息  
首先查看结构 desc v$sgainfo
然后查询 select * from v$sgainfo;
      查具体的分配状况
        有两种方法  ①直接查看:show parameter db_cache_size;
                    ②用动态性能视图查看:、
首先查看结构  desc v$parameter
                       然后查询  select * from v$parameter;
      设置 SGA参数
         alter system set db_cache_size=24M;
(这是某一具体参数,要想生效需重启数据库;参数单位必须大写 )
6、会话
      1)查某一客户正在访问服务器
          首先查看结构 desc v$session
          然后查询 select sid,SERIAL#,username from v$session where username is not null;
      2)使某一客户不能访问服务器
          Alter system kill session '序列号, serial';
7、进程
     1)查看后台进程
         首先查看结构 desc v$bgprocess
         然后查询 select name from v$bgprocess;
    2)查看正在运行的后台进程
         首先查看结构 desc v$bgprocess
         然后查询 select name from v$bgprocess where paddr !=’00’;
     3)服务器进程
        首先查看结构 desc v$process
        然后查询 select username from v$process;
8、查看Oracle版本
      首先查看结构 desc v$version
      然后查询  select * from v$version;
9、查所有的动态向能视图及动态性能表
      首先查看结构 desc v$fixed_table
      然后查询 select name from v$fixed_table;
10、查动态向能视图
select name from v$fixed_table where name like 'V$%';
 
二 数据字典视图:
 

序号
文件名
含义
1
dba_tablespaces
查询数据库结构信息(表空间)
2
dba_data_files
查询数据库结构信息(数据文件)
3
dba_users
查询用户信息
4
dict
当前用户可访问的所有的数据字典视图
5
dict_columns
显示数据字典视图中每个列的含义
6
obj
显示当前用户所拥有的对象信息,比如:表、视图、       索引、函数、过程等
7
dba_objects
显示所有用户所拥有的对象信息
8
dba_segments
sys下操作,查询所有用户表所占用空间信息
9
user_segments
当前用户操作,比如在scott用户操作,查询当前用户表所占用空间信息
10
dual
获取函数返回值
11
ind
查看当前用户所拥有的所有索引及索引统计信息
12
seq
查看当前用户所拥有的所有序列
13
tab
查看当前用户所拥有的表、视图和序列

 
1、可以访问到的所有数据字典视图
         首先查看结构 desc dict
         然后查询 select * from dict; 
2、列信息
1) user可以使用的数据字典视图
        select table_name from dict where table_name like ‘ USER%’ ;
2)客户表的数据字典视图
        select table_name from dict where table_name like 'USER_TAB%';
3)客户表列的数据字典视图
        select * from dict where table_name like 'USER_TAB_COLUMNS%'
3、查每个数据字典视图结构
       首先查看结构 desc dict_columns
       然后查询 select * from dict_columns where table_name='DBA_TABLESPACES';
     (以其中一个数据字典视图为例)
4、显示当前用户所有对象信息
        首先查看结构 desc obj
         因为一行显示的宽度不够,所以先设置宽度
          col OBJECT_NAME,CREATED format a60;
         然后查询
        select OBJECT_NAME,OBJECT_TYPE,CREATED from obj;
查看 sys下表的信息
        select OBJECT_NAME,OBJECT_TYPE,CREATED from obj where OBJECT_TYPE= 'TABLE';
查看 SCOTT用户下的信息
       首先查看结构 desc dba_objects
       设置宽度 col OBJECT_NAME format a20;
       然后查询 select OBJECT_NAME, OBJECT_TYPE,CREATED from dba_objects where OWNER='SCOTT';
5、利用查表空间的信息
        首先查看结构 desc dba_tablespaces
        然后查询 select TABLESPACE_NAME from dba_tablespaces;
     (与动态性能视图对比,结果一样。)
6、查数据库所有的数据文件信息
        首先查看结构 desc dba_data_files
        设置宽度 col FILE_NAME format a60;
        然后查询 select FILE_NAME,BYTES from dba_data_files;
7、查 scott客户下的用户信息
     首先查看结构 desc dba_users
     然后查询 select USERNAME,ACCOUNT_STATUS,CREATED from dba_users where USERNAME='SCOTT';
8、查当前客户下表、试图、序列信息
      首先查看结构 desc tab
      然后查询 select * from tab;
9、查当前客户下所有表索引信息
      首先查看结构 desc ind
      然后查询 select INDEX_NAME,INDEX_TYPE,TABLE_OWNER,TABLE_NAME, UNIQUENESS from ind;
     (如要查某一个表的信息则在后边加条件以指明是哪一个表 )
10、查看序列信息
     首先查看结构 desc seq
     然后查询 select SEQUENCE_NAME from seq;
 
三 数据字典
数据字典视图表
 

类型
用途
dba_xxx
只有DBA可以访问,查询所有数据库的信息
all_xxx
查询本用户及可访问的用户所拥有的数据信息
user_xxx
查询本用户所拥有的数据信息

 
   1、数据对象的定义结构(保留到数据字典里)
1)查看 Scott下所有的数据对象的定义
         首先查看结构  desc obj
         然后查询  select OBJECT_NAME, OBJECT_TYPE from obj;
2)查看表 emp的定义信息(使用本身函数提取相关信息)
        set long 4000(设置显示内容的长度)
         select dbms_metadata.get_ddl('TABLE','EMP') dll from dual;
     (对象的定义信息都到 dual中查)
3)查看索引的定义
      select dbms_metadata.get_ddl('INDEX','PK_EMP') from dual;
2、对象占用的空间
1)客户表的占用空间信息
     首先查看结构 desc user_segments
     设置宽度 col SEGMENT_NAME format a20;
      然后查询 select SEGMENT_NAME,TABLESPACE_NAME, BYTES from user_segments;
2)查具体的某一表的占用空间信息,以 EMP为例
     select SEGMENT_NAME,TABLESPACE_NAME, BYTES,BLOCKS from user_segments where SEGMENT_NAME='EMP';
3)查使用的空间大小和剩余空间信息(但得先用 analyze命令解析,关键)
     解析 analyze table emp compute statistics;
     查看结构 desc user_tables
     查询 select EMPTY_BLOCKS,BLOCKS from user_tables where TABLE_NAME='EMP';
3、列信息 ( user_tab_columns)
     首先查看结构 desc user_tab_columns
     设置列宽 col data_column format a15;
            col data_type format a15;
            col data_default format a15;
       然后查询 select data_column, data_type,data_default from user_tab_columns where table_name =’DEPT’;
4、查看表的约束信息
1)用户约束关系
          首先查看结构 desc user_constraints
          然后查询 select owner,constraint_name,constraint_type from user_constraints;
2)查看具体某列的约束
         首先查看结构 desc user_cons_columns
         设置列宽 col owner format a15;
             col table_name format a15;
         然后查询 select owner,constraint_name,table_name_position from user_cons_columns;
3)查表与表的约束
        Select a.constraint_name,a.constraint_type,b.column_name,b.position from user_constraints a,user_cons_column b where a. constraint_name=b. constraint_name and a.table_name=EMP’;
5、查看某客户的权限信息
      首先查看结构 desc dba_role_privs
      然后查询 select grantee,granted_role from dba_role_privs where grantee=’SCOTT’;
      (grantee 被授予权限的角色; granted_role授予的权限)




本文转自 vfast_chenxy 51CTO博客,原文链接:http://blog.51cto.com/chenxy/711161,如需转载请自行联系原作者
相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
3月前
|
存储 人工智能 Cloud Native
云栖重磅|从数据到智能:Data+AI驱动的云原生数据库
在9月20日2024云栖大会上,阿里云智能集团副总裁,数据库产品事业部负责人,ACM、CCF、IEEE会士(Fellow)李飞飞发表《从数据到智能:Data+AI驱动的云原生数据库》主题演讲。他表示,数据是生成式AI的核心资产,大模型时代的数据管理系统需具备多模处理和实时分析能力。阿里云瑶池将数据+AI全面融合,构建一站式多模数据管理平台,以数据驱动决策与创新,为用户提供像“搭积木”一样易用、好用、高可用的使用体验。
云栖重磅|从数据到智能:Data+AI驱动的云原生数据库
|
3月前
|
XML Java 数据库连接
性能提升秘籍:如何高效使用Java连接池管理数据库连接
在Java应用中,数据库连接管理至关重要。随着访问量增加,频繁创建和关闭连接会影响性能。为此,Java连接池技术应运而生,如HikariCP。本文通过代码示例介绍如何引入HikariCP依赖、配置连接池参数及使用连接池高效管理数据库连接,提升系统性能。
83 5
|
24天前
|
数据采集 数据库 Python
有哪些方法可以验证用户输入数据的格式是否符合数据库的要求?
有哪些方法可以验证用户输入数据的格式是否符合数据库的要求?
130 75
|
3月前
|
存储 监控 数据处理
flink 向doris 数据库写入数据时出现背压如何排查?
本文介绍了如何确定和解决Flink任务向Doris数据库写入数据时遇到的背压问题。首先通过Flink Web UI和性能指标监控识别背压,然后从Doris数据库性能、网络连接稳定性、Flink任务数据处理逻辑及资源配置等方面排查原因,并通过分析相关日志进一步定位问题。
246 61
|
2月前
|
SQL 存储 运维
从建模到运维:联犀如何完美融入时序数据库 TDengine 实现物联网数据流畅管理
本篇文章是“2024,我想和 TDengine 谈谈”征文活动的三等奖作品。文章从一个具体的业务场景出发,分析了企业在面对海量时序数据时的挑战,并提出了利用 TDengine 高效处理和存储数据的方法,帮助企业解决在数据采集、存储、分析等方面的痛点。通过这篇文章,作者不仅展示了自己对数据处理技术的理解,还进一步阐释了时序数据库在行业中的潜力与应用价值,为读者提供了很多实际的操作思路和技术选型的参考。
47 1
|
2月前
|
存储 Java easyexcel
招行面试:100万级别数据的Excel,如何秒级导入到数据库?
本文由40岁老架构师尼恩撰写,分享了应对招商银行Java后端面试绝命12题的经验。文章详细介绍了如何通过系统化准备,在面试中展示强大的技术实力。针对百万级数据的Excel导入难题,尼恩推荐使用阿里巴巴开源的EasyExcel框架,并结合高性能分片读取、Disruptor队列缓冲和高并发批量写入的架构方案,实现高效的数据处理。此外,文章还提供了完整的代码示例和配置说明,帮助读者快速掌握相关技能。建议读者参考《尼恩Java面试宝典PDF》进行系统化刷题,提升面试竞争力。关注公众号【技术自由圈】可获取更多技术资源和指导。
|
19天前
|
缓存 关系型数据库 MySQL
【深入了解MySQL】优化查询性能与数据库设计的深度总结
本文详细介绍了MySQL查询优化和数据库设计技巧,涵盖基础优化、高级技巧及性能监控。
148 0
|
2月前
|
前端开发 JavaScript 数据库
获取数据库中字段的数据作为下拉框选项
获取数据库中字段的数据作为下拉框选项
61 5
|
3月前
|
SQL 关系型数据库 数据库
国产数据实战之docker部署MyWebSQL数据库管理工具
【10月更文挑战第23天】国产数据实战之docker部署MyWebSQL数据库管理工具
253 4
国产数据实战之docker部署MyWebSQL数据库管理工具
|
3月前
|
关系型数据库 MySQL 数据库
GBase 数据库如何像MYSQL一样存放多行数据
GBase 数据库如何像MYSQL一样存放多行数据

热门文章

最新文章