【MySQL笔记】INFORMATION_SCHEMA数据库

介绍

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_%');

查看数据库服务器上的数据库

SELECT SCHEMA_NAME AS  'database'
FROM INFORMATION_SCHEMA.SCHEMATA LIMIT 0 , 30

查看某个数据库里面的数据表

SELECT table_name
FROM INFORMATION_SCHEMA.TABLES
WHERE table_schema = '某一个数据库的名称' LIMIT 0 , 30

查看某个数据表里面的字段

SELECT COLUMN_NAME, DATA_TYPE, IS_NULLABLE, COLUMN_DEFAULT
FROM INFORMATION_SCHEMA.COLUMNS
WHERE table_name = '某一张表的名字' AND table_schema = '某一个数据库的名称' LIMIT 0 , 30

查看某个表下面的索引信息

SELECT *
FROM INFORMATION_SCHEMA.STATISTICS
WHERE table_name = 'authors'AND table_schema = '某一个数据库的名称' LIMIT 0 , 30

查看某个数据库里面数据和索引的大小(M)

SELECT SUM( DATA_LENGTH ) /1024 /1024, SUM( INDEX_LENGTH ) /1024 /1024
FROM INFORMATION_SCHEMA.TABLES
WHERE table_schema = '某一个数据库的名称' 

参考:https://www.cnblogs.com/qiyebao/p/4164772.html

posted @   .Neterr  阅读(167)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构

喜欢请打赏

扫描二维码打赏

了解更多

点击右上角即可分享
微信分享提示