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

以上就是数据库报错“Unknown database”:为什么我的SQL语句无法找到目标数据库?的详细内容,更多请关注其它相关文章!