MySQL中schema与database完全等价,因CREATE SCHEMA和CREATE DATABASE为同义语句,且不支持库内多schema,仅通过多个database实现逻辑分组。

MySQL 中的 schema 就是数据库(database)本身,两者完全等价,没有层级或命名空间上的区别。
为什么 MySQL 里 schema = database?
MySQL 遵循 SQL 标准中对 schema 的宽泛定义,但实现上做了简化:
- CREATE SCHEMA 和 CREATE DATABASE 是同义语句,执行效果一模一样
- 你用
CREATE SCHEMA myapp;或CREATE DATABASE myapp;,结果都是新建一个名为myapp的数据库 - 系统表
INFORMATION_SCHEMA和performance_schema虽然名字带 “schema”,但它们本身就是独立的数据库,不是某个数据库内部的子结构
和其他数据库的区别在哪?
这是最容易混淆的地方——MySQL 不支持“库内多 schema”这种结构:
-
PostgreSQL / Oracle / SQL Server:一个 database 可包含多个 schema(如
public、hr、finance),同一库下不同用户或模块可隔离使用不同 schema - MySQL:没有库内命名空间机制。你想逻辑分组,只能靠建多个 database(即多个 schema),再通过权限控制用户能访问哪些库
- 比如想区分开发/测试/生产表?MySQL 常见做法是建
myapp_dev、myapp_test、myapp_prod三个库,而不是在一个库下建三个 schema
日常操作中怎么用 schema?
所有涉及 database 的命令,都可以用 schema 替代,语法完全兼容:
-
USE mydb;→ 切换到名为mydb的 schema(也就是 database) -
SHOW CREATE SCHEMA mydb;→ 查看该 schema 的创建语句(实际就是CREATE DATABASE语句) -
DROP SCHEMA mydb;→ 删除这个 schema(等价于DROP DATABASE mydb;) - 跨库查表时写法:
SELECT * FROM mydb.users;,这里的mydb就是 schema 名,也是 database 名
别被术语带偏:schema 不是“表结构”
有人误以为 schema 指的是单个表的字段定义(比如 CREATE TABLE 的那一套),这是混淆了 “schema” 和 “table schema”(表结构):
- 整个数据库叫 schema(MySQL 中 = database)
- 一张表的列名、类型、约束等定义,叫 table schema 或 table definition,它只是数据库 schema 的一部分
- MySQL 没有
ALTER SCHEMA这种修改整个库结构的命令;要改表结构,得用ALTER TABLE










