




主流PHP框架不自动创建数据库,因其默认假设数据库已存在,且创建操作需高权限、属部署阶段任务;应通过原生PDO执行CREATE DATABASE IF NOT EXISTS建库,再配置框架连接该库。
PHP 原生用 mysqli 或 PDO 创建数据库的操作,**不能直接在主流框架(如 Laravel、ThinkPHP、CodeIgniter)的模型或迁移系统中复用**——框架不认你手动建的库名,也不自动加载它;但你可以用原生方式建库,再让框架连上去。
主流 PHP 框架默认假设数据库已存在,它们聚焦在表结构(migration)、ORM 和查询上。创建数据库属于 DBA 或部署阶段操作,权限敏感(需要 CREATE DATABASE),框架通常不默认赋予该权限,也不在运行时动态建库。
php artisan migrate 会报错:SQLSTATE[HY000] [1049] Unknown database 'xxx',除非你先手动建好库Db::connect() 会抛出异常,不会自动创建.env 或 database.php)里的 DB_DATABASE 是“要连哪个库”,不是“建哪个库”推荐在部署脚本或安装向导中用原生 PDO 执行 CREATE DATABASE,而不是塞进控制器或命令行命令

CREATE DATABASE 权限(MySQL 中:执行 GRANT CREATE ON *.* TO 'user'@'host';)CREATE DATABASE 'myapp';;对:CREATE DATABASE myapp;)IF NOT EXISTS 避免重复建库报错:CREATE DATABASE IF NOT EXISTS myapp CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
PDO::exec("USE myapp") 或重连新库,否则后续 migration 仍可能失败示例(CLI 脚本 init-db.php):
try {
$pdo = new PDO("mysql:host=$host", $user, $pass, [
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
]);
$pdo->exec("CREATE DATABASE IF NOT EXISTS $database CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci");
echo "✅ 数据库 '$database' 已准备就绪\n";
} catch (PDOException $e) {
die("❌ 建库失败: " . $e->getMessage());
}
建完库后,只需更新框架配置,让它知道连哪儿——和原来一样,不需额外代码。
.env 中的 DB_DATABASE=myapp,然后跑 php artisan migrate
config/database.php 里的 'database' => 'myapp',再调 Db::execute("CREATE TABLE ...") 或用 migrate 插件utf8mb4,框架连接参数也要显式指定(Laravel 的 DB_CHARSET 和 DB_COLLATION 必须匹配)真正容易被忽略的是权限和字符集一致性——建库用 utf8,但框架连的时候设了 utf8mb4,某些 emoji 字段就会出乱码或截断;反过来,用户有建库权限,但没授 ALTER 或 INDEX 权,migration 也可能中途失败。