数据库报错“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语句无法找到目标数据库?的详细内容,更多请关注其它相关文章!