登录
首页 >  数据库 >  MySQL

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

时间:2024-11-08 22:27:58 214浏览 收藏

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

数据库报错“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语句无法找到目标数据库?》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布数据库相关知识,快来关注吧!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>