postgrepsql 查看单表大小

1. 在数据库中查单个表

select pg_size_pretty(pg_relation_size(‘table_name‘));

2. 查出并按大小排序

SELECT table_schema || ‘.‘ || table_name AS table_full_name, pg_size_pretty(pg_total_relation_size(‘"‘ || table_schema || ‘"."‘ || table_name || ‘"‘)) AS size
FROM information_schema.tables
ORDER BY pg_total_relation_size(‘"‘ || table_schema || ‘"."‘ || table_name || ‘"‘) DESC limit 20

3. 查出表大小按大小排序并分离data与index

SELECT
    table_name,
    pg_size_pretty(table_size) AS table_size,
    pg_size_pretty(indexes_size) AS indexes_size,
    pg_size_pretty(total_size) AS total_size
FROM (
    SELECT
        table_name,
        pg_table_size(table_name) AS table_size,
        pg_indexes_size(table_name) AS indexes_size,
        pg_total_relation_size(table_name) AS total_size
    FROM (
        SELECT (‘"‘ || table_schema || ‘"."‘ || table_name || ‘"‘) AS table_name
        FROM information_schema.tables
    ) AS all_tables
    ORDER BY total_size DESC
) AS pretty_sizes

原文地址:https://www.cnblogs.com/zacky31/p/8677932.html

时间: 2024-11-18 02:55:34

postgrepsql 查看单表大小的相关文章

查看数据表大小

--返回每个数据表大小: create table tmp (name varchar(50),rows int,reserved varchar(50),data varchar(50),index_size varchar(50),unused varchar(50))insert into tmp (name,rows,reserved,data,index_size,unused) exec sp_msforeachTable @Command1="sp_spaceused '?'&qu

SQL Server查看所有表大小,所占空间

将数据库的所在机器所有数据库名称及其大小查询出来 2.将数据库下的所有表的名称及其大小查询出来 请高手指点! 1.查看所有数据库相关信息,包裹存储路径等. use master select * from dbo.sysdatabases 2. 以SQL2000自带PUBS为例 exec sp_MSForEachTable @precommand=N'create table ###(表名 sysname,记录数 int,保留空间 Nvarchar(10),使用空间 varchar(10),索引

SQL Server查看所有表大小、表行数和占用空间信息

一.查看表名和对应的数据行数select  a.name as '表名',b.rows as '表数据行数'from sysobjects a inner join sysindexes bon a.id = b.idwhere   a.type = 'u'and b.indid in (0,1)--and a.name not like 't%'order by b.rows desc 其实本来只想找一个方法能查询一下 数据库 的大小,没想到这个方法还能查询数据库中 各个数据表 的大小,嗯,挺

mysql单表限制

mysql单表的限制 一.MySQL数据库的MyISAM存储 引擎单表大小限制已经不是有MySQL数据库本身来决定(限制扩大到64pb),而是由所在主机的OS上面的文件系统来决定了. 在mysql5.0版本之前,myisam存储引擎默认表的大小4Gb,可以用一下命令来查看: [[email protected] test]# cd /data/mysql/mysql_3306/data/test [[email protected] test]# myisamchk -dv t2 MyISAM

MySQL单表百万数据记录分页性能优化

原文地址:http://www.cnblogs.com/lyroge/p/3837886.html MySQL单表百万数据记录分页性能优化 背景: 自己的一个网站,由于单表的数据记录高达了一百万条,造成数据访问很慢,Google分析的后台经常报告超时,尤其是页码大的页面更是慢的不行. 测试环境: 先让我们熟悉下基本的sql语句,来查看下我们将要测试表的基本信息 use infomation_schemaSELECT * FROM TABLES WHERE TABLE_SCHEMA = 'dbna

MySQL 单表百万数据记录分页性能优化

来源:一颗卤蛋 链接:http://www.cnblogs.com/lyroge/p/3837886.html 背景: 自己的一个网站,由于单表的数据记录高达了一百万条,造成数据访问很慢,Google分析的后台经常报告超时,尤其是页码大的页面更是慢的不行. 测试环境: 先让我们熟悉下基本的sql语句,来查看下我们将要测试表的基本信息 use infomation_schemaSELECT * FROM TABLES WHERE TABLE_SCHEMA = ‘dbname’ AND TABLE_

MySQL单表百万数据记录分页性能优化,转载

背景: 自己的一个网站,由于单表的数据记录高达了一百万条,造成数据访问很慢,Google分析的后台经常报告超时,尤其是页码大的页面更是慢的不行. 测试环境: 先让我们熟悉下基本的sql语句,来查看下我们将要测试表的基本信息 use infomation_schemaSELECT * FROM TABLES WHERE TABLE_SCHEMA = 'dbname' AND TABLE_NAME = 'product' 查询结果: 从上图中我们可以看到表的基本信息: 表行数:866633平均每行的

大数据单表存储方案

背景: 10w+用户 每个用户每天会产生有效记录1000条,记录组成=用户ID.时间戳.字段1.字段2.字段N 每条记录长度约为1K 每个用户每天累计产生数据量=1000K,即1M 每月产生数据量为:30M 每年产生的数据量为:360M,记录数=10003012=36w条 这些数据的特点是:一次写入,多次读取,中间不做任何修改! 需求: 每个用户产生的数据,需要保存5年以上,能够支持随时查询,每次查询的时间跨度不超过3天. 问题: 使用传统的关系型数据库(MSSQL.MySQL),如何存储这些海

oracle数据库之单表查询

作为一合格的测试人员对数据库的单表查询.多表查询.分组查询.子查询等等这些基本查询方法还是要会的.不然到企业中,容易被一些人鄙视,或者说如果数据库学不好,表查不明白,那么对自己能力来说也是一种侮辱,因为你可以证明自己,你是可以的,尤其是你在面试的时候面对面试官的给你出的一道sql语句题目,你能马上用你的套路把这道题做出了,那么恭喜你过了第一个小关卡.ok,我们今天学习一下数据库中的第一个查询,也是最简单,容易入门的查看----单表查询. 我们在上一篇中创建了一个classinfo和student