ошибка базы данных sequelize без сообщения об ошибке - PullRequest
0 голосов
/ 25 ноября 2018

Я впервые использую PostgreSQL, и я создаю REST API, который использует sequelize для postgresql, expressjs и nodejs.
Я создал пользователя, и у каждого пользователя было много посылок.Я сейчас создаю посылку, которая принадлежит пользователю, используя 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 *;"
}

Код миграции участка

 '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');
      }
    };

Код модели участка

'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;
};

Контроллер посылок

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));
            }
    }

1 Ответ

0 голосов
/ 26 ноября 2018

Я проверил базу данных и увидел столбец, который, как мне казалось, я удалил.Мне пришлось запустить sequelize db: migrate: undo, а затем снова выполнить sequelize db: migrate, чтобы включить мои изменения, т.е. фактически удалить этот столбец.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...