mysql的information_schema浅析

embedded/2024/11/9 16:43:07/

information_schema 是 MySQL 中的一个虚拟数据库,它包含了关于 MySQL 服务器的所有元数据。

information_schema 作用

元数据管理:提供关于数据库、表、列、索引、权限等的信息。
性能优化:帮助了解数据库结构和索引使用情况,便于进行性能分析和优化。
安全和权限管理:查询用户和权限信息,帮助进行安全管理。
数据库维护:提供数据库、表、列的详细信息,便于进行维护和诊断。

常用表及其结构

information_schema 包含多个表,每个表提供不同方面的信息。以下是一些常用表的详细结构和使用方法。

  1. SCHEMATA 表
    存储数据库的相关信息。

结构:

SCHEMA_NAME:数据库名称
DEFAULT_CHARACTER_SET_NAME:默认字符集
DEFAULT_COLLATION_NAME:默认校对规则

查询所有数据库

SELECT SCHEMA_NAME FROM information_schema.SCHEMATA;
  1. TABLES 表
    存储表的信息,包括表名、表类型、存储引擎等。

结构:

TABLE_SCHEMA:数据库名称
TABLE_NAME:表名称
TABLE_TYPE:表类型(BASE TABLE或VIEW)
ENGINE:存储引擎
TABLE_ROWS:表中的行数

查询某个数据库中的所有表:

SELECT TABLE_NAME FROM information_schema.TABLES WHERE TABLE_SCHEMA = 'your_database';
  1. COLUMNS 表
    存储列的信息,包括列名、数据类型、是否可以为空等。

结构:

TABLE_SCHEMA:数据库名称
TABLE_NAME:表名称
COLUMN_NAME:列名称
DATA_TYPE:数据类型
IS_NULLABLE:是否可以为空
COLUMN_DEFAULT:默认值

查询某个表的列信息:

SELECT COLUMN_NAME, DATA_TYPE, IS_NULLABLE, COLUMN_DEFAULT
FROM information_schema.COLUMNS
WHERE TABLE_SCHEMA = 'your_database' AND TABLE_NAME = 'your_table';
  1. STATISTICS 表
    存储索引的信息。

结构:

TABLE_SCHEMA:数据库名称
TABLE_NAME:表名称
INDEX_NAME:索引名称
COLUMN_NAME:列名称
NON_UNIQUE:是否唯一索引

查询某个表的索引信息:

SELECT INDEX_NAME, COLUMN_NAME, NON_UNIQUE
FROM information_schema.STATISTICS
WHERE TABLE_SCHEMA = 'your_database' AND TABLE_NAME = 'your_table';
  1. USER_PRIVILEGES 表
    存储用户权限的信息。

结构:

GRANTEE:授予者(用户@主机)
PRIVILEGE_TYPE:权限类型
IS_GRANTABLE:是否可授予

查询当前用户的权限:

SELECT PRIVILEGE_TYPE
FROM information_schema.USER_PRIVILEGES
WHERE GRANTEE = "'your_user'@'your_host'";
  1. PROCESSLIST 表
    存储当前正在运行的查询。

结构:

ID:连接 ID
USER:用户名
HOST:主机名
DB:数据库名称
COMMAND:命令类型
TIME:执行时间
STATE:状态
INFO:查询信息

查询当前正在运行的查询:

SELECT * FROM information_schema.PROCESSLIST;

获取所有数据库名称

SELECT SCHEMA_NAME FROM information_schema.SCHEMATA;

获取某个数据库的所有表

SELECT TABLE_NAME FROM information_schema.TABLES WHERE TABLE_SCHEMA = 'your_database';

获取某个表的列信息

SELECT COLUMN_NAME, DATA_TYPE, IS_NULLABLE, COLUMN_DEFAULT
FROM information_schema.COLUMNS
WHERE TABLE_SCHEMA = 'your_database' AND TABLE_NAME = 'your_table';

获取某个表的索引信息

SELECT INDEX_NAME, COLUMN_NAME, NON_UNIQUE
FROM information_schema.STATISTICS
WHERE TABLE_SCHEMA = 'your_database' AND TABLE_NAME = 'your_table';

获取当前用户的权限

SELECT PRIVILEGE_TYPE
FROM information_schema.USER_PRIVILEGES
WHERE GRANTEE = "'your_user'@'your_host'";

其他重要表
CHARACTER_SETS 表
提供服务器支持的字符集信息。

SELECT * FROM information_schema.CHARACTER_SETS;

COLLATIONS 表
提供服务器支持的校对规则信息。

SELECT * FROM information_schema.COLLATIONS;

ENGINES 表
提供服务器支持的存储引擎信息。

SELECT * FROM information_schema.ENGINES;

VIEWS 表
提供视图的信息。

SELECT * FROM information_schema.VIEWS;

ROUTINES 表
提供存储过程和函数的信息。

SELECT * FROM information_schema.ROUTINES WHERE ROUTINE_SCHEMA = 'your_database';

总结
information_schema 是一个非常强大的工具,提供了对 MySQL 数据库元数据的全面访问。通过熟练使用 information_schema,可以更好地理解和管理你的数据库,从而提高性能和安全性。无论是日常管理、性能优化还是安全性检查,information_schema 都提供了必要的信息支持。


http://www.ppmy.cn/embedded/52483.html

相关文章

6-2 归并排序

6-2 归并排序 分数 10 全屏浏览 切换布局 作者 软件工程DS&A课程组 单位 燕山大学 以下代码采用分而治之算法实现归并排序。请补充函数mergesort()的代码。提示:mergesort()函数可用递归实现,其中参…

线程池概念、线程池的不同创建方式、线程池的拒绝策略

文章目录 💐线程池概念以及什么是工厂模式💐标准库中的线程池💐什么是工厂模式?💐ThreadPoolExecutor💐模拟实现线程池 💐线程池概念以及什么是工厂模式 线程的诞生是因为,频繁的创…

【unity笔记】四、Enviro- Sky and Weather插件使用

一、 简介 Enviro内置 RP、URP、HDRP,开箱即用。 动态天空 随附的天空系统经过精心设计,以实现最佳性能和灵活性。使用多种颜色渐变,而不是调整人工数字。为您的项目创建独特且非常逼真的天空非常简单! 灯光 由 Enviro 控制的逼…

云原生周刊:Harbor v2.11 版本发布 | 2024.6.17

开源项目推荐 Descheduler Descheduler 是一个工具,可用于优化 Kubernetes 集群中 Pod 的部署位置。它可以找到可以移动的 Pod,并将其驱逐,让默认调度器将它们重新调度到更合适的节点上。 Prowler Prowler 是一款适用于 AWS、Azure、GCP …

修改ppt注册表,导出高分辨率图片

参考:PPT中导出高分辨率图片的方法 修改ppt注册表,导出高分辨率图片:【具体步骤】 1、运行-输入regedit,打开注册表编辑器; 2、找到ppt中选项,按下面路径找。 3、鼠标右键新建-DWORD(32位)(D)&#xff0c…

微信小程序之横向列表展示

效果图 参考微信小程序可看 代码&#xff1a; <view class"lbtClass"><view class"swiper-container"><scroll-view class"swiper" scroll-x"true" :scroll-left"scrollLeft"><block v-for"(six…

【STM32】中断应用概述

前面我们知道在手册中有一个中断向量表&#xff0c;初步了解了中断的概念。 1.NVIC简介 NVIC是嵌套向量中断控制器&#xff0c;控制着整个芯片中断相关的功能&#xff0c;它跟内核紧密耦合&#xff0c;是内核里面的一个外设。 在固件库中&#xff0c;NVIC的结构体定义可谓是…

SQLite 3 优化批量数据存储操作---事务transaction机制

0、事务操作 事务的目的是为了保证数据的一致性和完整性。 事务&#xff08;Transaction&#xff09;具有以下四个标准属性&#xff0c;通常根据首字母缩写为 ACID&#xff1a; 原子性&#xff08;Atomicity&#xff09;&#xff1a;确保工作单位内的所有操作都成功完成&…