文章目录 前言 1、切换数据库 2、查看所有数据库容量大小 3、查看指定数据库使用大小 4、查看表使用大小 5、查看所有数据库容量大小 6、查看所有数据库各表容量大小 7、查看指定数据库容量大小 8、查看指定数据库各表容量大小...总结 前言 CentOS7 安装MySQL8详细步骤 CentOS7 环境下MySQL常用命令 在mysql中有一个默认的数据表information_schema,information_schema...这张数据表保存了MySQL服务器所有数据库的信息。...如数据库名,数据库的表,表栏的数据类型与访问权限等。...再简单点,这台MySQL服务器上,到底有哪些数据库、各个数据库有哪些表,每张表的字段类型是什么,各个数据库要什么权限才能访问,等等信息都保存在information_schema表里面,所以请勿删改此表
MySQL数据库占用的空间、表记录的行数在MySQL的 information_schema 数据库。...在该库中有一个 TABLES 表,这个表主要字段分别是: TABLE_SCHEMA -- 数据库名 TABLE_NAME -- 表名 ENGINE -- 所使用的存储引擎 TABLES_ROWS --...记录数 DATA_LENGTH -- 数据大小 INDEX_LENGTH -- 索引大小 查询方法 查询某个数据库的空间大小 SELECT concat(round(sum(DATA_LENGTH/1024.../1024),2),'MB') as data FROM TABLES WHERE table_schema='要查询的数据库名字'; 查询某个数据库中某个表的空间大小 SELECT concat(round...='要查询的表名';
create table #Data(name varchar(100),row varchar(100),reserved varchar(100),data...
第一章:表空间的拓展 ① 查看剩余表空间大小 查询剩余表空间(单位:M),小于1M将不显示。...③ 通过新增表空间文件拓展表空间 拓展表空间方法,可以看到表空间文件 NCC_DATA01_1-23 共同组成了表空间 NCC_DATA01,所以我们直接在存储表空间路径的基础上再加上一个新的序列号表空间文件就好了...下面设置的是默认 500M 大小,以后剩余控件不足时,每次自动增加 200M。...ORALCE_HOME\ORADATA\NNC_DATA01_23.DBF' size 500M autoextend on next 200M maxsize unlimited; ④ 查看表空间已分配大小...查看表空间和已分配大小(单位:M) select tablespace_name, sum(bytes) / 1024 / 1024 from dba_data_files group by tablespace_name
查看一个数据中所有表的相关信息: (1)可以在命令下使用show table status \G命令查看: (2)如果想知道MySQL数据库中每个表占用的空间、表记录的行数的话,可以打开MySQL的 information_schema...:数据大小 INDEX_LENGTH:索引大小 其他字段请参考MySQL的手册,我们只需要了解这几个就足够了。...所以要知道一个表占用空间的大小,那就相当于是 数据大小 + 索引大小 即可。...例:查看mysql库容量大小 select table_schema as '数据库', sum(table_rows) as '记录数', sum(truncate(data_length/1024...'; 4.查看指定数据库各表容量大小 例:查看mysql库各表容量大小 select table_schema as '数据库', table_name as '表名', table_rows as
– 1.切换 USE information_schema; – 2.查看数据库使用大小 SELECT concat( round( sum(data_length / 1024 / 1024...), 2 ), 'MB' ) AS DATA FROM TABLES WHERE table_schema = 'user_server'; – 3.查看表使用大小 SELECT
MySQL 8.0以前,存放在以.frm为后缀的文件里 MySQL 8.0以后,表结构定义存放在系统数据表中 --查看test库表t的信息 desc test.t; show columns from...表数据的存放位置由参数innodb_file_per_table控制: 设置为OFF,表的数据存放在系统共享表空间(ibdata为前缀的文件) 设置为ON,表数据存储在一个以.ibd为后缀,以表名为前缀的文件中...表数据单独存放成一个文件更容易管理,在我们执行drop table命令的时候,系统会直接删除这个文件,但如果是放在共享表空间中,即使表删掉空间也不会回收。 InnoDB的标记删除?...假设我们删除了R5这条记录,InnoDB引擎只会将R5这条记录标记为删除,并不是将页中该位置的数据置空,磁盘文件大小并不会缩小,这就是标记删除。...如何减少空洞,收缩表空间? 重建表。 如何重建表?
导读:深入学习MySQL的时候总是习惯性的和Oracle数据库进行比较。在学习MySQL InnoDB的存储结构的时候也免不了跟Oracle进行比较。...Oracle的数据存储有表空间、段、区、块、数据文件;MySQL InnoDB的存储管理也类似,但是MySQL增加了一个共享表空间和独立表空间的概念。...一、基本概念 共享表空间:Innodb的所有数据保存在一个单独的表空间里面,而这个表空间可以由很多个文件组成,一个表可以跨多个文件存在,所以其大小限制不再是文件大小的限制,而是其自身的限制。...默认的文件名为:ibdata1 初始化为10M 二、查看数据库的表空间 mysql> show variables like 'innodb_data%'; 我本地库比较小表空间主要由一个文件组成:ibdata1...以下是摘自mysql官方的一些介绍: 共享表空间的优点 表空间可以分成多个文件存放到各个磁盘,所以表也就可以分成多个文件存放在磁盘上,表的大小不受磁盘大小的限制(很多文档描述有点问题)。
Linux区分大小写规则 数据库名与表名严格区分大小写; 表的别名严格区分大小写; 列名与列的别名忽略大小写; 变量名严格区分大小写; windows下均不区分大小写。...配置支持大小写 Linux下配置my.cnf文件来决定是否支持大小写。...默认支持区分大小写,即等同于配置: lower_case_table_names=0 不区分大小写配置成如下即可: lower_case_table_names=1 一般情况下,此配置文件位于,/etc...通过vi命令进行修改,保存,重启mysql,即可生效。
临时表是执行sql语句过程中创建的中间过渡表,例如多表联合操作,就需要建立临时表 查看临时表的使用状态 mysql>show global status like 'created_tmp%'; created_tmp_tables...每次创建临时表时都会增加 created_tmp_disk_tables 如果是在磁盘上创建临时表,它会增加 created_tmp_files 表示MySQL服务创建的临时文件数 比较理想的配置是:...created_tmp_disk_tables / created_tmp_tables *100% <= 25% 再看一下临时表的配置: show variables like '%tmp_table_size...%'; tmp_table_size的默认值是32M,说明只有32M以下的临时表才能全部放在内存中,超过的就会用到硬盘临时表 可以适当增加此变量的值,例如 mysql> set session tmp_table_size
在MySQL数据库中,有一个内置的database叫做information_schema, 该数据库中的tables表包含了数据库中所有表的基本信息,tables表结构如下: mysql> use information_schema...; Database changed mysql> describe tables; +-----------------+---------------------+------+-----+----...-------------+------+-----+---------+-------+ 21 rows in set (0.03 sec) 下面介绍几个主要关键字段: TABLE_SCHEMA: 表所属的数据库名...TABLE_NAME: 表名 TABLE_ROWS: 表行数 DATA_LENGTH: 数据总大小 INDEX_LENGTH: 索引总大小 DATA_FREE: 磁盘碎片大小 查看表大小语句示例如下:...mysql> select table_schema, table_name, concat(truncate(sum(DATA_LENGTH)/1024/1024,2),' MB') as data_size
碎片产生的原因 (1)表的存储会出现碎片化,每当删除了一行内容,该段空间就会变为空白、被留空,而在一段时间内的大量删除操作,会使这种留空的空间变得比存储列表内容所使用的空间更大; (2)当执行插入操作时...,MySQL会尝试使用空白空间,但如果某个空白空间一直没有被大小合适的数据占用,仍然无法将其彻底占用,就形成了碎片; (3)当MySQL对数据进行扫描时,它扫描的对象实际是列表的容量需求上限,也就是数据被写入的区域中处于峰值位置的部分...; 例如: 一个表有1万行,每行10字节,会占用10万字节存储空间,执行删除操作,只留一行,实际内容只剩下10字节,但MySQL在读取时,仍看做是10万字节的表进行处理,所以,碎片越多,就会越来越影响查询性能...查看表碎片大小 (1)查看某个表的碎片大小 mysql> SHOW TABLE STATUS LIKE '表名'; 结果中’Data_free’列的值就是碎片大小 ?...where table_schema not in ('information_schema', 'mysql') and data_free > 0; 清除表碎片 (1)MyISAM表 mysql
数据库的表空间是用来存储数据的逻辑空间,也是存储数据的最大逻辑单元,其下还有段、区、页等逻辑数据类型。表空间设计是为了提升更高的IO,不同处理数据的解耦,便于管理。...独立表空间数据可以通过第三方工具进行分析和数据的抽取。还可以通过单独恢复独立表空间。 每个表文件表空间,允许通过监视表空间数据文件的大小来监视表大小。...因此,当结合此设置使用独立表空间时,可能会有性能改进。 共享表空间中的表的大小受到64TB表空间大小限制。...擅长MySQL、Redis、MongoDB数据库高可用设计和运维故障处理、备份恢复、升级迁移、性能优化。自学通过了MySQL OCP 5.6和MySQL OCP 5.7认证。...2年多开发经验,10年数据库运维工作经验,其中专职做MySQL工作8年;曾经担任过项目经理、数据库经理、数据仓库架构师、MySQL技术专家、DBA等职务;涉及行业:金融(银行、理财)、物流、游戏、医疗、
SELECT table_name, table_rows, data_length + index_length, CONCAT( ...
表的存储会出现碎片化,每当删除了一行内容,该段空间就会变为空白 当执行插入操作时,MySQL会尝试使用空白空间,但如果某个空白空间一直没有被大小合适的数据占用,就形成了碎片 当MySQL扫描表时,扫描的对象实际是包含碎片空间的...例如 一个表有1万行,每行10字节,会占用10万字节存储空间 执行删除操作,只留一行,实际内容只剩下10字节 但MySQL在读取时,仍看做是10万字节的表进行处理 所以,碎片越多,就会越来越影响查询性能...查看表碎片大小 01 查看某个表的碎片大小 mysql> SHOW TABLE STATUS LIKE '表名'; 结果中'Data_free'列的值就是碎片大小 02 列出所有已经产生碎片的表...table_schema not in ('information_schema', 'mysql') and data_free > 0; 清除表碎片 01 MyISAM表 mysql> optimize...table 表名 02 InnoDB表 mysql> alter table 表名 engine=InnoDB 建议 清除碎片操作会暂时锁表,数据量越大,耗费的时间越长 可以做个脚本,定期在访问低谷时间执行
从 MySQL5.7.11开始,MySQL对InnoDB支持存储在单独表空间中的表的数据加密 。此功能为物理表空间数据文件提供静态加密。...2 测试加密表空间 2.1 创建加密的新表 创建一张新表,并添加ENCRYPTION='Y' ,加密表空间 mysql> create table test1( id int primary key...另外,keyring_file_data也是可以动态调整的,比较简单,就不演示了 2.4 统计表空间加密的表 想要知道哪些表的表空间加密了,可以通过数据字典表里查看 mysql> SELECT TABLE_SCHEMA...重启数据库后,会发现,又自动生成了keyring文件 ?...那么再将原keyring还原,然后再重启数据库,会发现又能成功了 mysql> select * from test1; +----+---------+ | id | name | +----
引发这个其妙现象的就是 MySQL 的表空间碎片。 什么是表空间碎片?...:删除了日志表的很多数据,但是 MySQL 的磁盘空间并没有降低。...PS:这种不释放空间的设计多半和惰性删除有关,早期设计数据库时,使用的 IO 设备一般是机械盘,读写性能比 SSD 差很多,所以删除操作一般不会直接触发磁盘上的数据删除。...怎么查看表空间碎片 MySQL 的系统表记录了表空间的使用情况,可以用如下查询检查: SELECT CONCAT(table_schema,'.'...FROM information_schema.TABLES WHERE table_schema = 'tablename' ORDER by data_free desc; data_free 指表空间碎片的总空间大小
查看数据库占用空间 SELECT CONCAT(ROUND((sum(DATA_LENGTH)+sum(INDEX_LENGTH))/(1024*1024),2),'M') as 'Datebase Size...' FROM information_schema.TABLES where TABLE_SCHEMA='数据库名称'; 查看表占用空间 SELECT CONCAT(ROUND(SUM(DATA_LENGTH...1024*1024), 2), ' MB') AS 'Total Table Size' FROM information_schema.TABLES WHERE table_schema LIKE '数据库名称...information_schema.TABLES WHERE table_schema LIKE '数据库名称'; 查看库中表详细信息 结果包括:表名、记录数、此表占用空间、此表索引占用空间、此表总占用空间...+index_length)/(1024*1024),2),'M') AS'Total'FROM information_schema.TABLES WHERE table_schema LIKE '数据库名称
前因 早上上班,发现监控数据中,好几张表的所占数据空间突增,有的突增甚至达到了8G,仔细检测数据库之后,没有发现数据异常,那么问题出在哪里?...如何获取表大小 表的大小,是存储在INFORMATION_SCHEMA.TABLES中吗?mysql的官方文档说: 对于MyISAM,DATA_LENGTH是数据文件的长度,以字节为单位。...具体来说,它是聚集索引大小(以页为单位)乘以InnoDB页大小。 这就意味着,使用InnoDB时,我们所获取的表空间大小,是不准确的。...通过使用sysbench对mysql进行基准测试,批量数据插入数据库,可以发现,从 INFORMATION_SCHEMA.TABLES 获取的 data_length 和 index_length 所定义的表大小并不是实时更新的...问题的原因找到了,tables表虽然可以获取到表空间的大小,但是该数据不是实时的。
领取专属 10元无门槛券
手把手带您无忧上云