MySQL 系统表

MySQL系统表是数据库管理系统为了存储关于数据库本身的信息而创建的一系列特殊表。这些表通常包含元数据(metadata),如用户账户、权限、数据库结构定义以及其他用于管理和维护数据库的重要信息。

以下是一些在MySQL中常见的系统表或相关概念:

  1. information_schema 数据库:

    • 这是一个虚拟数据库,不占用实际磁盘空间,它提供了一套标准的方式来查看MySQL服务器中所有数据库的元数据。
    • 例如,TABLESCOLUMNSSCHEMATAVIEWSTRIGGERS等表分别提供了关于所有数据库中的表、列、模式、视图和触发器的信息。
  2. mysql 数据库下的系统表:

    • mysql.user:存储了用户的账号、密码哈希及全局级别的权限信息。
    • mysql.db:记录了每个数据库及其对应用户的访问权限。
    • mysql.tables_priv:存储针对特定表的权限信息。
    • mysql.columns_priv:存储针对特定表的列级别权限信息。
    • mysql.procs_priv:存储存储过程和函数的执行权限。
    • mysql.roles_mapping(MySQL 8.0+):角色映射关系表。
    • mysql.global_variablesmysql.session_variables:包含了全局和会话级别的系统变量设置。
  3. performance_schema 数据库(MySQL 5.5以后引入):

    • 提供了一组系统表来监视MySQL服务器内部操作的性能指标,包括线程状态、锁信息、内存分配情况等。
  4. sys 数据库(MySQL 5.7以后引入):

    • 是一个可读性更好的性能_schema视图集合,便于查询和理解MySQL的运行状况。

请注意,直接修改这些系统表的内容需要谨慎,因为它们对数据库系统的正常运行至关重要。通常,管理员通过SQL语句或MySQL管理工具来更新系统表内容以进行用户权限管理或其他配置变更。

相关推荐
l1t11 小时前
利用DeepSeek实现服务器客户端模式的DuckDB原型
服务器·c语言·数据库·人工智能·postgresql·协议·duckdb
MarkHard12315 小时前
如何利用redis使用一个滑动窗口限流
数据库·redis·缓存
island131417 小时前
【Redis#10】渐进式遍历 | 数据库管理 | redis_cli | RES
数据库·redis·bootstrap
心想事成的幸运大王17 小时前
Redis的过期策略
数据库·redis·缓存
倔强的石头_17 小时前
CentOS 上安装KingbaseES(ISO包)详细教程
数据库
2401_8979300618 小时前
使用Docker轻松部署Neo4j图数据库
数据库·docker·neo4j
诗句藏于尽头18 小时前
Django模型与数据库表映射的两种方式
数据库·python·django
寻星探路18 小时前
数据库造神计划第六天---增删改查(CRUD)(2)
java·大数据·数据库
盖世英雄酱5813619 小时前
Read timed out问题 排查
java·数据库·后端
云动雨颤20 小时前
Spring Boot配置优化:Tomcat+数据库+缓存+日志,全场景教程
数据库·spring boot·tomcat