PHP批量建库需先用mysqli_connect()或PDO连接MySQL服务层(不指定数据库名),再循环执行带IF NOT EXISTS的CREATE DATABASE语句,并显式指定字符集与排序规则,同时确保用户拥有全局CREATE权限。

PHP 本身不直接提供“批量建库”命令,mysqli 或 PDO 连接的是某个具体数据库实例,建库操作必须通过有权限的数据库用户(如 root)连接到 MySQL 的服务层(即不指定 dbname),再逐条执行 CREATE DATABASE 语句——所以“批量”是靠循环实现的,不是单条 PHP 函数调用能完成的。
用 mysqli_connect() 连接 MySQL 服务层(不指定数据库名)
这是最关键的前置条件:如果连接时写了第三个参数(数据库名),就无法执行建库语句,会报错 ERROR 1046 (3D000): No database selected。
- 正确写法:
mysqli_connect('localhost', 'root', 'password')—— 省略第四个参数 - 错误写法:
mysqli_connect('localhost', 'root', 'password', 'test')—— 此时连接已绑定到 test 库,CREATE DATABASE会被拒绝 - 连接后建议立即检查:
mysqli_error($conn),避免权限不足或连接失败被忽略
循环执行 CREATE DATABASE 语句(带 IF NOT EXISTS 防重)
MySQL 5.7+ 支持 IF NOT EXISTS,避免重复建库报错中断脚本;但要注意字符集和排序规则需显式指定,否则依赖 MySQL 全局默认值,跨环境易不一致。
- 推荐语句模板:
CREATE DATABASE IF NOT EXISTS `{$dbname}` CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci - 数据库名必须用反引号包裹,防止含短横线、数字开头等非法标识符问题
- 不要在循环里反复
mysqli_close(),保持单次连接复用,否则频繁握手影响性能 - 示例片段:
$dbnames = ['app_logs', 'app_cache', 'app_analytics'];
$conn = mysqli_connect('localhost', 'root', 'pass');
foreach ($dbnames as $name) {
$sql = "CREATE DATABASE IF NOT EXISTS `{$name}` CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci";
if (!mysqli_query($conn, $sql)) {
echo "Failed to create {$name}: " . mysqli_error($conn) . "\n";
}
}
用 PDO 批量建库时注意异常模式和事务无效性
CREATE DATABASE 是 DDL 语句,在 MySQL 中自动提交,无法回滚。即使你开了 PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,也不能用事务包裹多个建库操作来实现原子性。
立即学习“PHP免费学习笔记(深入)”;
- 必须单独捕获每个
exec()调用的异常,不能依赖 try/catch 包裹整个循环 - 连接 DSN 必须省略
dbname=xxx,例如:mysql:host=localhost;port=3306 - 字符集应在 DSN 中声明(如
;charset=utf8mb4),但建库语句里仍要显式写CHARACTER SET,因为 DSN 的 charset 只影响连接通信,不决定新库默认编码
真正容易被忽略的是权限粒度:MySQL 用户必须拥有 CREATE 权限,且该权限需授予 *.*(全局),而不是某个具体库下——否则即使连接成功,建库也会静默失败或报 Access denied。批量脚本跑不通时,先用命令行 mysql -u root -p -e "CREATE DATABASE test123" 验证权限是否到位。










