数据库报错“Unknown database”:为什么我的SQL语句无法找到目标数据库?

数据库报错“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('注册成功!') };

© 版权声明
THE END
喜欢就支持一下吧
点赞7 分享