本文翻译自 MariaDB 官方技术文档,全面解析 CREATE DATABASE 语句的语法与使用场景。以下为详细说明。

语法结构
CREATE [OR REPLACE] {DATABASE | SCHEMA} [IF NOT EXISTS] db_name
[create_specification] ...
create_specification:
[DEFAULT] CHARACTER SET [=] charset_name
| [DEFAULT] COLLATE [=] collation_name
语句说明
CREATE DATABASE 用于创建一个指定名称的数据库。执行该命令需要拥有 database 对象的 CREATE 权限。注意,CREATE SCHEMA 是 CREATE DATABASE 的完全等价同义词,二者功能一致。
若在语句中使用了 IF NOT EXISTS 子句,当目标数据库已存在时,MariaDB 不会抛出错误,而是仅返回一条 warning(警告)信息,避免脚本中断。
OR REPLACE 选项
从 MariaDB 10.1.3 版本起,引入了 OR REPLACE 子句。该选项本质是语法糖,相当于先执行 DROP DATABASE IF EXISTS db_name;,再执行 CREATE DATABASE db_name ...;,即先删除已存在的数据库再重新创建。
IF NOT EXISTS 选项
当使用 IF NOT EXISTS 时,如果数据库已经存在,MariaDB 仅生成一条 warning,而不会报错。这一特性在自动化脚本中非常实用,能有效防止因重复建库导致的流程中断。
实际示例
以下通过几个直观案例展示不同场景下的执行结果:
CREATE DATABASE db1;
Query OK, 1 row affected (0.18 sec)
CREATE DATABASE db1;
ERROR 1007 (HY000): Can't create database 'db1'; database exists
CREATE OR REPLACE DATABASE db1;
Query OK, 2 rows affected (0.00 sec)
CREATE DATABASE IF NOT EXISTS db1;
Query OK, 1 row affected, 1 warning (0.01 sec)
SHOW WARNINGS;
+-------+------+----------------------------------------------+
| Level | Code | Message |
+-------+------+----------------------------------------------+
| Note | 1007 | Can't create database 'db1'; database exists |
+-------+------+----------------------------------------------+
第一条命令成功创建数据库;第二次尝试因数据库已存在而报错;使用 OR REPLACE 后,先删除旧库再创建新库,因此返回 2 rows affected;最后使用 IF NOT EXISTS,数据库已存在但不报错,仅返回一行受影响记录及一条 warning。
指定字符集与排序规则
创建数据库时可以同时自定义默认字符集和排序规则。详细配置可参考“设置字符集和排序规则”相关章节。例如:
CREATE DATABASE czech_slovak_names
CHARACTER SET = 'keybcs2'
COLLATE = 'keybcs2_bin';
以上命令创建的数据库将采用 keybcs2 字符集和二进制排序规则,适用于处理捷克语、斯洛伐克语等特殊字符。
总结:CREATE DATABASE 是数据库创建的基础语句,结合 IF NOT EXISTS 或 OR REPLACE 选项,能够更灵活地控制建库行为,避免因重复创建导致的错误,省去手动先删后建的繁琐步骤。
