mysql在dockerizing express.js app后“字段列表中未知列国家”

g6baxovj  于 2021-06-21  发布在  Mysql
关注(0)|答案(1)|浏览(303)

我有这个express.js应用程序和一组mocha测试。不久前的某个时候,我取消了这个项目。在dockerizing之后,只有一半的测试通过了,因为mysql错误。为了生成这些sql语句,我使用bookshelf.js/knex.js。我不会显示所有的测试,因为它们都有一个共同的问题。
第一个测试运行此代码。

method.registerUser = (request, callBack) => {
    let {
        email,
        username,
        address,
        city,
        zip,
        state,
        password,
        country,
    } = request.body;

    password = hashPassword(decrypt(password));

    if(!testRegistration(request)) {
        return callBack ({
            success: false,
        });
    }

    let insert = {
        NAME: username,
        PASSWORD: password,
        EMAIL: email,
        ADDRESS: address,
        CITY: city,
        ZIP: zip,
        STATE: state,
        COUNTRY: country,
    };

    User.forge(insert)
        .save()
        .then((user) => {
            return callBack ({
                success: true,
            });
        })
        .catch(function (err) {
            logger.log(err);
            return callBack ({
                success: false,
            });
        });
}

在这里,它提供了向mysql数据库添加新用户的用户模型。用户模型由这个json定义。

"database_test" : {
        "client": "mysql",
        "connection": {
            "host": "DB",
            "database": "TERRA_TEST",
            "user": "root",
            "port": "3306",
            "password": "goon",
            "charset": "utf8"
        }
    },

我在每次测试之前都会运行一系列迁移,数据库的结果模式如下所示。

+----------+------------------+------+-----+---------+----------------+
| Field    | Type             | Null | Key | Default | Extra          |
+----------+------------------+------+-----+---------+----------------+
| id       | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| NAME     | varchar(255)     | YES  |     | NULL    |                |
| PASSWORD | varchar(255)     | YES  |     | NULL    |                |
| EMAIL    | varchar(255)     | YES  |     | NULL    |                |
| ADDRESS  | varchar(255)     | YES  |     | NULL    |                |
| CITY     | varchar(255)     | YES  |     | NULL    |                |
| ZIP      | varchar(30)      | YES  |     | NULL    |                |
| STATE    | varchar(255)     | YES  |     | NULL    |                |
| COUNTRY  | varchar(255)     | YES  |     | NULL    |                |
+----------+------------------+------+-----+---------+----------------+

但是,当执行该代码以创建新用户的测试运行时,它会失败并返回此错误。

code: 'ER_BAD_FIELD_ERROR',
  errno: 1054,
  sqlMessage: 'Unknown column \'COUNTRY\' in \'field list\'',
  sqlState: '42S22',
  index: 0,
  sql: 'insert into `USERS` (`ADDRESS`, `CITY`, `COUNTRY`, `EMAIL`, `NAME`, `PASSWORD`, `STATE`, `ZIP`) values (\'4909 Jean Manors\', \'New Parkerville\', \'Kiribati\', \'Matilde.Wiegand@hotmail.com\', \'Sarina_Anderson\', \'$2a$10$nsaL/4DyHquIlHKQOxjPiObBZJykbNlSZYCJCe0m3fREN4XD0c9o2\', \'Alaska\', \'01524\')' }

当我在mysql cli中运行这个sql代码时,应用它时没有错误。
另外,这里是docker compose的db部分

DB:
     image: mysql:5.7
     container_name: mysql
     restart: always
     environment:
         - MYSQL_ROOT_PASSWORD=goon
         - MYSQL_DATABASE=TERRA_TEST
         - MYSQL_USER=tester
         - MYSQL_PASSWORD=goon
         - DATABASE_HOST=docker-mysql
     ports:
         - "3306:3306"
     networks:
         - web_sql_bridge

你们中有谁知道为什么会发生这些错误以及如何修复它们吗?他们在完成项目后就开始了。在它运行所有测试没有错误之前?

mzaanser

mzaanser1#

如果问题是在docker之后开始的,那么可能您实际上正在运行到本地数据库的迁移,并在docker中针对db运行应用程序。
无论如何,这个问题目前没有足够的关于安装的信息来给出明确的答案。请平,如果你添加更多信息的问题,我会更新答案。
我们需要知道你是如何运行你的停靠设置。如何运行迁移。你有本地mysql安装和docker mysql服务器同时运行吗。您是否在某个时候停止了容器(从而丢失了迁移的数据设置)。基本上完整的代码再现您的问题将是必要的。

相关问题