PHP执行CREATE DATABASE后必须显式切换数据库,使用mysqli_select_db()或$mysqli->select_db(),不可依赖自动切换;USE语句虽可行但不推荐,因稳定性差且易导致状态不一致。

刚用 PHP 执行 CREATE DATABASE 语句后,不能直接用新库——因为当前连接仍绑定在原数据库(通常是 mysql 或未选库状态),必须显式切换。
PHP 建库后必须执行 mysqli_select_db() 或 mysqli::select_db()
MySQLi 连接对象默认不自动切换到刚创建的数据库。即使建库成功,后续 CREATE TABLE 等操作若没选库,会报错 No database selected。
- 使用面向对象风格:
$mysqli->select_db('new_db'),返回true表示成功 - 使用过程式风格:
mysqli_select_db($connection, 'new_db') - 注意:该函数不接受带反引号的库名,如
`my-db`会失败;应传纯名称my-db - 如果库名含特殊字符或短横线,确保已用合法标识符命名,且未在 SQL 中误加引号传入函数
用 mysqli_query() 发送 USE new_db 也能切换,但不推荐
虽然 mysqli_query($conn, "USE `new_db`") 在语法上可行,但它绕过了连接层的数据库上下文管理,容易和 select_db() 混用导致状态不一致,尤其在长连接或连接池场景下不可靠。
-
SELECT DATABASE()查询可验证当前所选库,建库后立即查,结果仍是NULL或旧库名 -
USE是 SQL 语句,受 SQL 模式(如sql_mode=STRICT_TRANS_TABLES)影响,而select_db()是 MySQLi 底层 C API 调用,更稳定 - PDO 用户同理:建库后需调用
$pdo->exec("USE new_db")或重建 PDO 实例指定dbname=new_db
建库 + 切库必须分两步,且需检查每步返回值
常见错误是只检查 CREATE DATABASE 是否成功,忽略 select_db() 可能失败(比如权限不足、库名拼写错误、字符集不兼容)。
立即学习“PHP免费学习笔记(深入)”;
-
CREATE DATABASE成功不代表你能访问它——用户可能只有CREATE权限,没有USAGE或SELECT - 建议顺序:
mysqli_query($conn, "CREATE DATABASE IF NOT EXISTS testdb CHARACTER SET utf8mb4")→ 检查返回值 → 再调select_db()→ 再检查 - 字符集不匹配时(如建库用
utf8mb4,但连接默认latin1),后续建表可能报Invalid default value for 'xxx',应在建库后立刻mysqli_set_charset($conn, 'utf8mb4')
最易被忽略的是权限粒度:MySQL 的 CREATE DATABASE 权限不隐含对该库的任何操作权限,select_db() 成功只说明库存在且名字合法,不代表你能往里建表——那得看 CREATE 权限是否授予了这个具体库。











