GP数据库中,查找某个数据库表都有栏位名称,可以查找其系统表。
GP数据库的表可分为:
1、创建普通表,创建分区表。
2、修改表结构。
3、创建及修改表空间。
GP数据库建表模板,通过excel拷贝数据字典,即可生成对应的gp数据库建表语句脚本,简单易用。
表空间是数据库中最大的逻辑单位与存储空间单位 数据库系统通过表空间为数据库对象分配空间 表空间在物理上体现为磁盘数据文件 每一个表空间由一个或多个数据文件组成 一个数据文件只可与一个表空间相联系 这是逻辑与物理的统一 了解表空间和数据文件的的属性及使用率 是数据库管理员的一项重要职责 在本文中笔者将以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
查询表空间使用情况 select atablespace_name "表空间名称", 100-round((nvl(bbytes_free,0)/abytes_alloc)100,2) "占用率(%)", round(abytes_alloc/1024/1024,2) "容量(M)", round(nvl(bbytes_free,0)/1024/1024,2) "空闲(M)", round((abytes_alloc-nvl(bbytes_free,0))/1024/1024,2) "使用(M)", Largest "最大扩展段(M)", to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') "采样时间" from (select ftablespace_name, sum(fbytes) bytes_alloc, sum(decode(fautoextensible,'YES',fmaxbytes,'NO',fbytes)) maxbytes from dba_data_files f group by tablespace_name) a, (select ftablespace_name, sum(fbytes) bytes_free from dba_free_space f group by tablespace_name) b, (select round(max(fflength)16/1024,2) Largest, tsname tablespace_name from sysfet$ ff, sysfile$ tf,systs$ ts where tsts#=ffts# and fffile#=tfrelfile# and tsts#=tfts# group by tsname, tfblocks) c where atablespace_name = btablespace_name and atablespace_name = ctablespace_name 25 查询表空间的碎片程度 select tablespace_name,count(tablespace_name) from dba_free_space group by tablespace_name having count(tablespace_name)>10; alter tablespace name coalesce; alter table name deallocate unused; create or replace view ts_blocks_v as select tablespace_name,block_id,bytes,blocks,'free space' segment_name from dba_free_space union all select tablespace_name,block_id,bytes,blocks,segment_name from dba_extents; select from ts_blocks_v; select tablespace_name,sum(bytes),max(bytes),count(block_id) from dba_free_space group by tablespace_name; 26。查询有哪些数据库教程实例在运行 select inst_name from v$active_instances; =========================================================== ######### 创建数据库----look $ORACLE_HOME/rdbms/admin/buildallsql ############# create database db01 maxlogfiles 10 maxdatafiles 1024 maxinstances 2 logfile GROUP 1 ('/u01/oradata/db01/log_01_db01rdo') SIZE 15M, GROUP 2 ('/u01/oradata/db01/log_02_db01rdo') SIZE 15M, GROUP 3 ('/u01/oradata/db01/log_03_db01rdo') SIZE 15M, datafile 'u01/oradata/db01/system_01_db01dbf') SIZE 100M, undo tablespace UNDO datafile '/u01/oradata/db01/undo_01_db01dbf' SIZE 40M
select
bfile_name 物理文件名,
btablespace_name 表空间,
bbytes/1024/1024 大小M,
(bbytes-sum(nvl(abytes,0)))/1024/1024 已使用M,
substr((bbytes-sum(nvl(abytes,0)))/(bbytes)100,1,5) 利用率
from dba_free_space a,dba_data_files b
where afile_id=bfile_id
group by btablespace_name,bfile_name,bbytes
order by btablespace_name
该语句通过查询dba_free_space,dba_data_files,dba_tablespaces这三个数据字典表,得到了表空间名称,表空间类型,区管理类型,以”兆”为单位的表空间大小,已使用的表空间大小及表空间利用率。dba_free_space表描述了表空间的空闲大小,dba_data_files表描述了数据库中的数据文件,dba_tablespaces表描述了数据库中的表空间。
上面语句中from子句后有三个select语句,每个select语句相当于一个视图,视图的名称分别为a、b、c,通过它们之间的关联关系,我们得到了表空间的相关信息。
1、因为oracle运行在Linux系统下,首先,要连接Linux系统。
2、连上后,进行oracle控制台。输入命令: sqlplus / as sysdba;
3、在sql命令行,输入:
SELECT UPPER(FTABLESPACE_NAME) "表空间名",DTOT_GROOTTE_MB "表空间大小(M)",DTOT_GROOTTE_MB - FTOTAL_BYTES "已使用空间(M)",
TO_CHAR(ROUND((DTOT_GROOTTE_MB - FTOTAL_BYTES) / DTOT_GROOTTE_MB 100,2),'99099') || '%' "使用比",FTOTAL_BYTES "空闲空间(M)",FMAX_BYTES "最大块(M)"
FROM (SELECT TABLESPACE_NAME,ROUND(SUM(BYTES) / (1024 1024), 2) TOTAL_BYTES,ROUND(MAX(BYTES) / (1024 1024), 2) MAX_BYTES,
FROM SYSDBA_FREE_SPACE,GROUP BY TABLESPACE_NAME) F,
(SELECT DDTABLESPACE_NAME,ROUND(SUM(DDBYTES) / (1024 1024), 2) TOT_GROOTTE_MB,
FROM SYSDBA_DATA_FILES DD,GROUP BY DDTABLESPACE_NAME) D,
WHERE DTABLESPACE_NAME = FTABLESPACE_NAME,ORDER BY 1;
4、这样就可以查看到相应结果。 完成效果图。
select atablespace_name "表空间名称",
100-round((nvl(bbytes_free,0)/abytes_alloc)100,2) "占用率(%)",
round(abytes_alloc/1024/1024,2) "容量(M)",
round(nvl(bbytes_free,0)/1024/1024,2) "空闲(M)",
round((abytes_alloc-nvl(bbytes_free,0))/1024/1024,2) "使用(M)",
Largest "最大扩展段(M)",
to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') "采样时间"
from (select ftablespace_name,
sum(fbytes) bytes_alloc,
sum(decode(fautoextensible,'YES',fmaxbytes,'NO',fbytes)) maxbytes
from dba_data_files f
group by tablespace_name) a,
(select ftablespace_name,
sum(fbytes) bytes_free
from dba_free_space f
group by tablespace_name) b,
(select round(max(fflength)16/1024,2) Largest,
tsname tablespace_name
from sysfet$ ff, sysfile$ tf,systs$ ts
where tsts#=ffts# and fffile#=tfrelfile# and tsts#=tfts#
group by tsname, tfblocks) c
where atablespace_name = btablespace_name and atablespace_name = ctablespace_name
1通过管理工具
开始->管理工具->性能(或者是运行里面输入
mmc)然后通过添加计数器添加
sql
的常用统计
然后在下面列出的项目里面选择用户连接就可以时时查询到数据库的连接数了。不过此方法的话需要有访问那台计算机的权限,就是要通过windows账户登陆进去才可以添加此计数器。
2通过系统表查询
select
from
[master][dbo][sysprocesses]
where
[dbid]
in
(
select
[dbid]
from
[master][dbo][sysdatabases]
where
name='dbname'
)
dbname
是需要查看的数据库,然后查询出来的行数,就是当前的连接数。不过里面还有一些别的状态可以做参考用。
例如:连到master这个数据库写如下语句
select
from
sysprocesses
where
dbid
in
(select
dbid
from
sysdatabases
where
name='mydatabase')
将所有连接mydatabase这个数据库的连接记录都求出来。
sysprocesses这个表记录所以连接到sql
server数据库的连接。
3通过系统的存储过程来查找
sp_who
'username'
username
是当然登陆sql的用户名,一般程序里面都会使用一个username来登陆sql这样通过这个用户名就能查看到此用户名登陆之后占用的连接了。
如果不写username,那么返回的就是所有的连接。
以上就是关于gp数据库节点使用率高,怎么定位是哪个表全部的内容,包括:gp数据库节点使用率高,怎么定位是哪个表、查询Oracle数据库表空间信息的方法、oracle 查询表空间使用情况与查询有哪些数据库实例在运行等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)