PostgreSQL
 sql >> Baza danych >  >> RDS >> PostgreSQL

Sekwencjonuj błąd ładowania Chętnego podczas dołączania powiązanego modelu

Mam działającą odpowiedź. W tym przykładzie mam schemat, w którym dział może mieć wiele stanowisk. Stanowisko będzie obejmowało dział, a dział będzie obejmował jego stanowiska.

modele/Dział.js

module.exports = (sequelize, DataTypes) => 
{
const Sequelize = require('sequelize');
const Department = sequelize.define('Department', 
{
    ...
}
Department.associate = function(models) {
    Department.hasMany(models.Position, {
      foreignKey: 'department_id',
      as: 'positions'
    });
};

return Department;
};

modele/Pozycja.js

module.exports = (sequelize, DataTypes) => 
{
const Sequelize = require('sequelize');
const Position = sequelize.define('Position', 
{
    ...
}

Position.associate = function(models) {
    Position.belongsTo(models.Department, {
        foreignKey: 'department_id',
        as: 'department',
        onDelete: 'CASCADE'
    });
};

return Position;
};

controllers/departmentController.js

exports.all = async function(req, res)
{
return Department
    .findAll({include: [ 'positions' ]})
    .then((data) => {
        if (!data) { return res.status(400).json({status: 400,message: 'Registro não encontrado', data: data }); }
        return res.status(200).json(data);
    })
    .catch((error) => {
        return res.status(400).json({message: 'Falha no banco de dados.', data: error})
    });
};

controllers/positionController.js

exports.all = async function(req, res)
{
return Position
    .findAll({include: [ 'department' ]})
    .then((data) => {
        if (!data) { return res.status(400).json({status: 400,message: 'Registro não encontrado', data: data }); }
        return res.status(200).json(data);
    })
    .catch((error) => {
        console.log(error);
        return res.status(400).json({message: 'Falha no banco de dados.', data: error})
    });
};


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Błąd zakleszczenia w instrukcji INSERT

  2. Konwertuj wartość z reprezentacji ciągu w bazie N na liczbową

  3. Konwertuj nazwę miesiąca na numer miesiąca w PostgreSQL

  4. pgAdmin III Dlaczego wyniki zapytań są skracane?

  5. Jakie jest oczekiwane zachowanie wielu funkcji zwracających zestaw w klauzuli SELECT?