一 动态性能视图:以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,如需转载请自行联系原作者