数据库报错“Unknown database”:为什么我的SQL语句无法找到目标数据库?
从现在开始,努力学习吧!本文主要讲解了等等相关知识点,我会在米云中持续更新相关的系列文章,欢迎大家关注并积极留言建议。下面就先一起来看一下本篇正文内容吧,希望能帮到你!

数据库操作时的常见错误:未指定数据库
如问题所示,程序在执行 sql 查询时遇到:”er_bad_db_error: unknown database” 的错误。这是因为 sql 语句中未指定要操作的数据库,导致数据库无法找到对应的表。
在 mysql 中,要指定数据库,需要在 sql 语句的开头添加 use 数据库名 语句。例如,
use my_db_01;
执行此语句后,所有后续的 sql 语句将针对数据库 my_db_01 执行。
在代码中,可以先使用 use 语句指定数据库,然后执行 sql 查询。例如,修改后的代码如下:
exports.regUser = (req, res) => {
// 1. 获取用户信息
const userinfo = req.body;
// 2. 指定数据库
db.query('USE my_db_01;');
// 3. 执行数据库操作,查重用户名
// 4. 定义 SQL 语句
const sql = 'SELECT * FROM getloonwh_users WHERE username=? AND usernumber=?';
// 5. 执行
db.query(sql, [userinfo.username, userinfo.usernumber], (err, results) => {
if (err) return res.cc(err);
if (results.length > 0) return res.send('已存在用户名!重新输入');
const sqlStr = 'INSERT INTO getloonwh_users SET ?';
db.query(sqlStr, { username: userinfo.username, usernumber: userinfo.usernumber }, (err, results) => {
if (err) return res.cc(err);
if (results.affectedRows !== 1) return res.cc('注册失败!');
res.send({ status: 0, msg: '注册成功!' });
});
});
// res.send('注册成功!')
};
终于介绍完啦!小伙伴们,这篇关于《数据库报错“Unknown database”:为什么我的SQL语句无法找到目标数据库?》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~米云公众号也会发布数据库相关知识,快来关注吧!
