在dockerizing express.js应用程序之后“字段列表中的未知列COUNTRY”

时间:2018-06-08 23:31:30

标签: mysql node.js docker-compose knex.js bookshelf.js

我有这个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,
            });
        });
}

这是它为User模型添加新用户到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:
     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

您是否有任何人知道为什么会发生这些错误以及如何解决这些错误?它们在对项目进行码头化后开始发生。在它运行所有测试之前没有错误?

1 个答案:

答案 0 :(得分:0)

如果在docker化之后问题就开始了,也许你实际上正在运行迁移到本地数据库并在docker中运行针对数据库的应用程序。

无论如何,问题目前还没有足够的关于设置的信息来给出明确的答案。如果您在问题中添加更多信息,请ping,我会更新答案。

我们需要知道您是如何运行dockerized设置的。你是如何运行迁移的?你有同时运行的本地mysql安装和docker mysql服务器吗?您是否在某个时刻停止容器(因此通过迁移失去数据设置)。基本上需要完整的代码来重现你的问题。