node.js - Sequelize 数据库错误且没有错误消息

标签 node.js postgresql express sequelize.js

这是我第一次使用 PostgreSQL,我正在创建一个 REST API,该 API 对 postgresql、expressjs 和 nodejs 使用sequelize。
我创建了一个用户,每个用户有很多地 block 。我现在正在创建一个属于用户的包裹,使用 userId 作为引用。我不断收到数据库 Sequelize 错误,但没有任何消息。它的例程是“checkInsertTarget”。

错误消息

{
    "name": "SequelizeDatabaseError",
    "parent": {
        "name": "error",
        "length": 190,
        "severity": "ERROR",
        "code": "42703",
        "position": "48",
        "file": "d:\\pginstaller.auto\\postgres.windows-x64\\src\\backend\\parser\\parse_target.c",
        "line": "1033",
        "routine": "checkInsertTargets",
        "sql": "INSERT INTO \"Parcels\" (\"id\",\"name\",\"delivered\",\"presentLoc\",\"destination\",\"description\",\"createdAt\",\"updatedAt\",\"userId\") VALUES (DEFAULT,'Shoe',false,'Onitsha','ESUT','black shoe, size 34','2018-11-25 15:48:13.100 +00:00','2018-11-25 15:48:13.100 +00:00','3') RETURNING *;"
    },
    "original": {
        "name": "error",
        "length": 190,
        "severity": "ERROR",
        "code": "42703",
        "position": "48",
        "file": "d:\\pginstaller.auto\\postgres.windows-x64\\src\\backend\\parser\\parse_target.c",
        "line": "1033",
        "routine": "checkInsertTargets",
        "sql": "INSERT INTO \"Parcels\" (\"id\",\"name\",\"delivered\",\"presentLoc\",\"destination\",\"description\",\"createdAt\",\"updatedAt\",\"userId\") VALUES (DEFAULT,'Shoe',false,'Onitsha','ESUT','black shoe, size 34','2018-11-25 15:48:13.100 +00:00','2018-11-25 15:48:13.100 +00:00','3') RETURNING *;"
    },
    "sql": "INSERT INTO \"Parcels\" (\"id\",\"name\",\"delivered\",\"presentLoc\",\"destination\",\"description\",\"createdAt\",\"updatedAt\",\"userId\") VALUES (DEFAULT,'Shoe',false,'Onitsha','ESUT','black shoe, size 34','2018-11-25 15:48:13.100 +00:00','2018-11-25 15:48:13.100 +00:00','3') RETURNING *;"
}

地 block 迁移代码

 'use strict';
    module.exports = {
      up: (queryInterface, Sequelize) => {
        return queryInterface.createTable('Parcels', {
          id: {
            allowNull: false,
            autoIncrement: true,
            primaryKey: true,
            type: Sequelize.INTEGER
          },
          name: {
            type: Sequelize.STRING
          },
          delivered: {
            type: Sequelize.BOOLEAN
          },
          presentLoc: {
            type: Sequelize.STRING
          },
          destination: {
            type: Sequelize.STRING
          },
          description: {
            type: Sequelize.STRING
          },
          createdAt: {
            allowNull: false,
            type: Sequelize.DATE
          },
          updatedAt: {
            allowNull: false,
            type: Sequelize.DATE
          },
          userId: {
            type: Sequelize.INTEGER,
            onDelete: 'CASCADE',
            references: {
              model: 'Users',
              key: 'id',
              as: 'userId',
            }
          }
        });
      },
      down: (queryInterface, Sequelize) => {
        return queryInterface.dropTable('Parcels');
      }
    };

地 block 模型代码

'use strict';
module.exports = (sequelize, DataTypes) => {
  const Parcel = sequelize.define('Parcel', {
    name: {
      type: DataTypes.STRING,
      allowNull: false
    },
    delivered: {
      type: DataTypes.BOOLEAN,
      defaultValue: false
    },
    presentLoc: {
      type: DataTypes.STRING,
      allowNull: false
    },
    destination: {
      type: DataTypes.STRING,
      allowNull: false
    },
    description: DataTypes.STRING,
  }, {});

  Parcel.associate = (models) => {
    Parcel.belongsTo(models.User, {
      foreignKey: 'userId',
      onDelete: 'CASCADE'
    })
  };
  return Parcel;
};

包裹 Controller

const Parcel = require('../models').Parcel;
const joiSchema = require('../joischema/parcelSchema');
const validator = require('../joischema/validator');

module.exports = {
    create(req, res) {
        const data = {
            name: req.body.name,
            description: req.body.description,
            destination: req.body.destination,
            presentLoc: req.body.presentLoc,
            userId: req.params.userId,
        };
        const valid = validator.isValid(req, res, joiSchema, data);
        if (valid != null){
            res.status(500).send(valid);
        }else{
            return Parcel
                .create(data)
                .then(parcel => res.status(201).send(parcel))
                .catch(error => res.status(400).send(error));
            }
    }

最佳答案

我检查了数据库,发现有一列我以为已删除。我必须运行 sequelize db:migrate:undo ,然后再次运行 sequelize db:migrate 以合并我的更改,即删除该列。

关于node.js - Sequelize 数据库错误且没有错误消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53469168/

相关文章:

postgresql - 在 where 子句中使用非常常见的值时查询速度慢

javascript - 运行 Nodemon 时出现问题 : "[nodemon] clean exit - waiting for changes before restart"

node.js - expressjs-向路由注入(inject)中间件失败

node.js - Express - 无法发送重定向,对预检请求的响应未通过访问控制检查

angularjs - 通过 Git 将简单 SPA 部署到 Azure

javascript - Ladda 不是用 node.js 定义的

javascript - 如何仅使用PG和Node返回PostgreSQL数据库结果?

postgresql - 为什么 postgres 官方 docker repo 不在构建时启动 db 服务?

node.js - 嵌套多个异步等待

javascript - Node - 跨平台编译 - PKG