检查使用共享表空间的表

检查使用共享表空间的表

最近接手一台新的数据库机器,发现某些库某些表没有ibd文件只有frm文件,而ibdata1文件一共有20G+,估计是使用了共享表空间

存放在ibdata1文件里

于是写了一个脚本,检查实例下哪些库哪些表使用了共享表空间,原理是如果有frm文件而没有ibd文件就认为是使用了共享表空间

#!/bin/bash
# Written by steven
# Name:        checktablesharespace.sh
# Version:      v1.0
# Function:     检查使用共享表空间的表结果存放在/tmp/checkresult.txt
# Create Date:  2016-08-27

dbs="school Report appeal bak  zabbix"   #输入要检查的数据库
dbpath="/data/mysql"  #输入实例所在路径

>/tmp/checkresult.txt

#备份
for db in $dbs
do

    cd  ${dbpath}${db}
    echo --------------${db}--------------- >> /tmp/checkresult.txt
    for i in `ls *.frm`
    do
        p=`echo $i|awk -F‘.frm‘  ‘{print $1}‘`

    if [ ! -s $p.ibd ]
    then
        echo $p >> /tmp/checkresult.txt
    fi
    done
    echo   >> /tmp/checkresult.txt

done

众所周知,共享表空间的坏处有很多,比如不能使用表空间传输,数据压缩和加密,重整表空间等等

如有不对的地方,欢迎大家拍砖o(∩_∩)o 

本文版权归作者所有,未经作者同意不得转载。

时间: 2024-10-05 10:40:09

检查使用共享表空间的表的相关文章

mysql 5.6 使用传输表空间迁移表或恢复误删除的表

mysql 5.6 使用传输表空间迁移表或恢复误删除的表 http://blog.csdn.net/lidan3959/article/details/25152623 以前在网上也看过一些对5.6传输表空间的介绍,不过都写的不够具体详细,今天有空就具体操作了一把,并详细记录了一下算留个档 一,简单说明:1),传输表空间的限制:   1,mysql 版本 5.6.6 及其以上,并且版本建议源和目标版本建议都是GA版并且大版本一样   2,表引擎为innodb并且开启独立表空间  innodb_f

Oracle创建表空间和表

创建表空间和表ORACLE物理上是由磁盘上的以下几种文件:数据文件和控制文件和LOGFILE构成的oracle中的表就是一张存储数据的表.表空间是逻辑上的划分.方便管理的.数据表空间 (Tablespace)         存放数据总是需要空间, Oracle把一个数据库按功能划分若干空间来保存数据.当然数据存放在磁盘最终是以文件形式,所以一盘一个数据表空间包含一个以上的物理文件数据表         在仓库,我们可能有多间房子,每个房子又有多个货架,每架又有多层. 我们在数据库中存放数据,最

4.windows和Linux下创建oracleusername表空间,表,插入数据,用户管理表等操作

进入超级管理员,运行下面命令 Window下创建数据库.表空间,用户,插入数据等操作 -- 01 创建表空间 -- 注意表空间的路径 依据实际安装环境进行调整 CREATE TABLESPACE ts_myscott LOGGING DATAFILE 'F:/app/to-to/oradata/orcl/ts_myscott.dbf' SIZE 10M EXTENT MANAGEMENT LOCAL; CREATE TABLESPACE ts_myscott2 LOGGING DATAFILE

4.windows和Linux下创建oracle用户名表空间,表,插入数据,用户管理表等操作

进入超级管理员,执行以下命令 Window下创建数据库,表空间,用户,插入数据等操作 -- 01 创建表空间 -- 注意表空间的路径 根据实际安装环境进行调整 CREATE TABLESPACE ts_myscott LOGGING DATAFILE 'F:/app/to-to/oradata/orcl/ts_myscott.dbf' SIZE 10M EXTENT MANAGEMENT LOCAL; CREATE TABLESPACE ts_myscott2 LOGGING DATAFILE

数据库实例: STOREBOOK > 表空间 > 编辑 表空间: USERS

ylbtech-Oracle:数据库实例: STOREBOOK  >  表空间  >  编辑 表空间: USERS 表空间  >  编辑 表空间: USERS 1. 一般信息返回顶部 1.1, 之一般信息 1.2, 之数据文件 1.3, 2. 存储返回顶部 2.1, 2.2, 3. 阈值返回顶部 3.1, 3.2, 4.返回顶部 4.1, 作者:ylbtech出处:http://ylbtech.cnblogs.com/本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,

数据库实例: STOREBOOK > 表空间 > 编辑 表空间: UNDOTBS1

ylbtech-Oracle:数据库实例: STOREBOOK  >  表空间  >  编辑 表空间: UNDOTBS1 表空间  >  编辑 表空间: UNDOTBS1 1. 一般信息返回顶部 1.1, 之一般信息 1.2, 之数据文件 1.3, 2. 存储返回顶部 2.1, 2.2, 3. 阈值返回顶部 3.1, 3.2, 4.返回顶部 4.1, 作者:ylbtech出处:http://ylbtech.cnblogs.com/本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保

数据库实例: STOREBOOK > 表空间 > 编辑 表空间: SYSAUX

ylbtech-Oracle:数据库实例: STOREBOOK  >  表空间  >  编辑 表空间: SYSAUX  表空间  >  编辑 表空间: SYSAUX 1. 一般信息返回顶部 1.1, 之一般信息 1.2, 之数据文件 1.3, 2. 存储返回顶部 2.1, 2.2, 3. 阈值返回顶部 3.1, 3.2, 4. 占有者返回顶部 4.1, 4.2, 5.返回顶部 5.1, 作者:ylbtech出处:http://ylbtech.cnblogs.com/本文版权归作者和博客园

数据库实例: STOREBOOK > 表空间 > 编辑 表空间: SYSTEM

ylbtech-Oracle:数据库实例: STOREBOOK  >  表空间  >  编辑 表空间: SYSTEM  表空间  >  编辑 表空间: SYSTEM 1. 一般信息返回顶部 1.1, 之一般信息 1.2, 之数据文件 1.3, 2. 存储返回顶部 2.1, 2.2, 3. 阈值返回顶部 3.1, 3.2, 4.返回顶部 4.1, 作者:ylbtech出处:http://ylbtech.cnblogs.com/本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段

Oracle表空间和表的入门操作指令

Oracle数据库-常用操作指令 查看端口号指令 netstat –a 清屏: SQL> clear scre; SQL> host cls; 表空间   建立表空间 SQL> create tablespace tc20 datafile 'e:\tc20_data_dbf' size 20m autoextend on next 5m maxsize 500m; 查询表空间名称 SQL> select tablespace_name,file_name from dba_dat