查询Oracle数据库表空间信息的方法

查询Oracle数据库表空间信息的方法,第1张

空间数据库中最大的逻辑单位与存储空间单位 数据库系统通过表空间为数据库对象分配空间 表空间在物理上体现为磁盘数据文件 每一个表空间由一个或多个数据文件组成 一个数据文件只可与一个表空间相联系 这是逻辑与物理的统一 了解表空间和数据文件的的属性及使用率 是数据库管理员的一项重要职责 在本文中笔者将以oracle为例 详细介绍查询Oracle数据库表空间信息和数据文件信息的方法 希望能帮助大家更深入了解表空间的知识和应用

一 如何查看Oracle数据库中表空间信息的方法

从Oracle数据库中工具入手

使用oracle enterprise manager console工具 这是oracle的客户端工具 当安装oracle服务器或客户端时会自动安装此工具 在windows *** 作系统上完成oracle安装后 通过下面的方法登录该工具 开始菜单——程序——Oracle OraHome ——Enterprise Manager Console(单击)——oracle enterprise manager console登录——选择 独立启动 单选框—— 确定 —— oracle enterprise manager console 独立 ——选择要登录的 实例名 ——d出 数据库连接信息 ——输入 用户名/口令 (一般使用sys用户) 连接身份 选择选择SYSDBA—— 确定 这时已经成功登录该工具 选择 存储 ——表空间 会看到如下的界面 该界面显示了表空间名称 表空间类型 区管理类型 以 兆 为单位的表空间大小 已使用的表空间大小及表空间利用率

从Oracle数据库中命令方法入手

通过查询数据库系统中的数据字典表(data dictionary tables)获取表空间的相关信息 首先使用客户端工具连接到数据库 这些工具可以是SQLPLUS字符工具 TOAD PL/SQL等 连接到数据库后执行如下的查询语句

select a a 表空间名称 c c 类型 c c 区管理 b b / / 表空间大小M (b b a a )/ / 已使用M substr((b b a a )/b b ) 利用率from(select tablespace_name a sum(nvl(bytes )) a from dba_free_space group by tablespace_name) a (select tablespace_name b sum(bytes) b from dba_data_files group by tablespace_name) b (select tablespace_name c contents c extent_management c from dba_tablespaces) cwhere a a =b b and c c =b b ;

该语句通过查询dba_free_space dba_data_files dba_tablespaces这三个数据字典表 得到了表空间名称 表空间类型 区管理类型 以 兆 为单位的表空间大小 已使用的表空间大小及表空间利用率 dba_free_space表描述了表空间的空闲大小 dba_data_files表描述了数据库中的数据文件 dba_tablespaces表描述了数据库中的表空间

上面语句中from子句后有三个select语句 每个select语句相当于一个视图 视图的名称分别为a b c 通过它们之间的关联关系 我们得到了表空间的相关信息

语句执行结果如下

上面描述中分别介绍了查看Oracle数据库中表空间信息的工具方法和命令方法

二 查询Oracle数据库中数据文件信息的方法

查看Oracle数据库中数据文件信息的工具方法

使用上面介绍过的方法登录oracle enterprise manager console工具 选择 存储 ——数据文件 会看到如下的界面 该界面显示了数据文件名称 表空间名称 以 兆 为单位的数据文件大小 已使用的数据文件大小及数据文件利用率

查看Oracle数据库中数据文件信息的命令方法

通过查询数据库系统中的数据字典表(data dictionary tables)获取数据文件的相关信息 首先使用客户端工具连接到数据库 这些工具可以是SQLPLUS字符工具 TOAD PL/SQL等 连接到数据库后执行如下的查询语句

select b file_name 物理文件名 b tablespace_name 表空间 b bytes/ / 大小M (b bytes sum(nvl(a bytes )))/ / 已使用M substr((b bytes sum(nvl(a bytes )))/(b bytes) ) 利用率from dba_free_space a dba_data_files bwhere a file_id=b file_idgroup by b tablespace_name b file_name b bytesorder by b tablespace_name

上面描述中分别介绍了查看Oracle数据库中数据文件信息的工具方法和命令方法

三 查看临时表空间和数据库文件的方法

在oracle数据库中 临时表空间主要用于用户在使用order by group by语句进行排序和汇总时所需的临时工作空间 要查询数据库中临时表空间的名称 大小及数据文件 可以查询数据字典dba_tablespaces及dba_data_files 命令如下

select a talbespace_name 表空间名称 b bytes 大小bytes b file_name 数据文件名from dba_tablespaces a dba_data_files bWhere a talbespace_name=b talbespace_name and ntents= TEMPORARY ;

查询结果如下

从oracle i开始 可以创建Temporary tablespace类表空间 即 临时 表空间 这类表空间使用临时文件 临时文件的信息被存储在数据字典V$tempfile中 命令如下

Select file# status name from V$tempfile;

查询数据字典V$tempfile结果如下

在上面介绍的方法中 建议掌握命令方法 因为你的环境可能没有图形工具 而SQLPLUS一般情况下都是可以使用的 有了命令脚本 很容易得到表空间和数据文件的相关信息 另外 数据库管理员应该多整理命令脚本 在需要时直接执行脚本以提高工作效率

lishixinzhi/Article/program/Oracle/201311/18471

是的,你可以查询表返回一条记录或者0条记录都行,然后用记录集的fields集合就可以取到列数,列名和每个列的类型和大小等信息。 Fields集合的一些属性的解释 ============================= ’以下为简写,正常情况需要rsFileds。。。但是Fields属于Recordset的一个默认集合,因此可以省略 rs() ’括号内可以是列名也可以是列的序号例如:rs("姓名")、rs(3) 都是是可以的 rs(3)Name ’返回列名 rs(3)Type ’返回列的类型 rs(3)Value ’返回当前行的值 rsFieldsCount ’返回列数

求采纳

SELECT

TableName=CASE WHEN Ccolumn_id=1 THEN Oname ELSE N'' END,

TableDesc=ISNULL(CASE WHEN Ccolumn_id=1 THEN PTB[value] END,N''),

Column_id=Ccolumn_id,

ColumnName=Cname,

PrimaryKey=ISNULL(IDXPrimaryKey,N''),

[IDENTITY]=CASE WHEN Cis_identity=1 THEN N'√'ELSE N'' END,

Computed=CASE WHEN Cis_computed=1 THEN N'√'ELSE N'' END,

Type=Tname,

Length=Cmax_length,

Precision=Cprecision,

Scale=Cscale,

NullAble=CASE WHEN Cis_nullable=1 THEN N'√'ELSE N'' END,

[Default]=ISNULL(Ddefinition,N''),

ColumnDesc=ISNULL(PFD[value],N''),

IndexName=ISNULL(IDXIndexName,N''),

IndexSort=ISNULL(IDXSort,N''),

Create_Date=OCreate_Date,

Modify_Date=OModify_date

FROM syscolumns C

INNER JOIN sysobjects O

ON C[object_id]=O[object_id]

AND Otype='U'

AND Ois_ms_shipped=0

INNER JOIN systypes T

ON Cuser_type_id=Tuser_type_id

LEFT JOIN sysdefault_constraints D

ON C[object_id]=Dparent_object_id

AND Ccolumn_id=Dparent_column_id

AND Cdefault_object_id=D[object_id]

LEFT JOIN sysextended_properties PFD

ON PFDclass=1

AND C[object_id]=PFDmajor_id

AND Ccolumn_id=PFDminor_id

-- AND PFDname='Caption' -- 字段说明对应的描述名称(一个字段可以添加多个不同name的描述)

LEFT JOIN sysextended_properties PTB

ON PTBclass=1

AND PTBminor_id=0

AND C[object_id]=PTBmajor_id

-- AND PFDname='Caption' -- 表说明对应的描述名称(一个表可以添加多个不同name的描述)

LEFT JOIN -- 索引及主键信息

(

SELECT

IDXC[object_id],

IDXCcolumn_id,

Sort=CASE INDEXKEY_PROPERTY(IDXC[object_id],IDXCindex_id,IDXCindex_column_id,'IsDescending')

WHEN 1 THEN 'DESC' WHEN 0 THEN 'ASC' ELSE '' END,

PrimaryKey=CASE WHEN IDXis_primary_key=1 THEN N'√'ELSE N'' END,

IndexName=IDXName

FROM sysindexes IDX

INNER JOIN sysindex_columns IDXC

ON IDX[object_id]=IDXC[object_id]

AND IDXindex_id=IDXCindex_id

LEFT JOIN syskey_constraints KC

ON IDX[object_id]=KC[parent_object_id]

AND IDXindex_id=KCunique_index_id

INNER JOIN -- 对于一个列包含多个索引的情况,只显示第1个索引信息

(

SELECT [object_id], Column_id, index_id=MIN(index_id)

FROM sysindex_columns

GROUP BY [object_id], Column_id

) IDXCUQ

ON IDXC[object_id]=IDXCUQ[object_id]

AND IDXCColumn_id=IDXCUQColumn_id

AND IDXCindex_id=IDXCUQindex_id

) IDX

ON C[object_id]=IDX[object_id]

AND Ccolumn_id=IDXcolumn_id

-- WHERE Oname=N'要查询的表' -- 如果只查询指定表,加上此条件 没有写的话,就是查询---该数据库的所有表

WHERE Oname='BusinessCardInfo' --这里是查询表BusinessCardInfo的所有字段属性。

ORDER BY Oname,Ccolumn_id

---------------------------------------------------------------------------------------------------

上面的也测试过了。没问题的。只显示指定表的个字段属性

上面这个方法是以前刚好要用网上一个叫“邹建”的写的,这里就借花献佛下。

其实这个写蛮麻烦的。想好记点就直接用 SP_HELP 表名

不过里面信息比较多,自己得去小找下。

以上就是关于查询Oracle数据库表空间信息的方法全部的内容,包括:查询Oracle数据库表空间信息的方法、如何在vb中查找一个数据库的一个表中有多少个属性、数据库中显示表的各个字段属性,它所用的命令是什么书上说实用describe,但是我用的时候说错误等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9298691.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-26
下一篇 2023-04-26

发表评论

登录后才能评论

评论列表(0条)

保存