INFORMATION_SCHEMA数据库介绍
删除mysql数据库某一张主键表的所有外键关系
SELECT CONCAT('alter table ', TABLE_NAME , ' drop foreign key ', constraint_name, ';') FROM information_schema.KEY_COLUMN_USAGE a WHERE a.TABLE_SCHEMA='某一个数据库的名称' AND a.constraint_name LIKE 'FK_Reference_%' AND REFERENCED_TABLE_NAME='某一张表的名字';
删除mysql数据库某一张主键表的所有索引
SELECT * FROM INFORMATION_SCHEMA.STATISTICS a WHERE a.TABLE_SCHEMA = '某一个数据库的名称' AND a.TABLE_NAME = '某一张表的名字' AND (a.INDEX_NAME LIKE 'FK_%' OR a.INDEX_NAME LIKE 'IX_%');
mysql中的默认“INFORMATION_SCHEMA”数据库介绍
INFORMATION_SCHEMA提供了访问数据库元数据的方式。
元数据是关于数据的数据,如数据库名或表名,列的数据类型,或访问权限等。
有些时候用于表述该信息的其他术语包括“数据词典”和“系统目录”。
下面举例子来说明用法,详细用法参看手册。
1,查看数据库服务器上的数据库
SELECT SCHEMA_NAME AS 'database' FROM INFORMATION_SCHEMA.SCHEMATA LIMIT 0 , 30
2,查看某个数据库里面的数据表
SELECT table_name FROM INFORMATION_SCHEMA.TABLES WHERE table_schema = '某一个数据库的名称' LIMIT 0 , 30
3,查看某个数据表里面的字段
SELECT COLUMN_NAME, DATA_TYPE, IS_NULLABLE, COLUMN_DEFAULT FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = '某一张表的名字' AND table_schema = '某一个数据库的名称' LIMIT 0 , 30
4,查看某个表下面的索引信息
SELECT * FROM INFORMATION_SCHEMA.STATISTICS WHERE table_name = 'authors'AND table_schema = '某一个数据库的名称' LIMIT 0 , 30
5,查看某个数据库里面数据和索引的大小(M)
SELECT SUM( DATA_LENGTH ) /1024 /1024, SUM( INDEX_LENGTH ) /1024 /1024 FROM INFORMATION_SCHEMA.TABLES WHERE table_schema = '某一个数据库的名称'