- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在不同的论坛上经常看到这个问题,但我一直无法解决它。我在 Sequelize 中使用 Express 和 PostgreSQL。
基本上我有两种模式:校园和学术经理。两者之间是一对一的关系,Campus 有一名学术经理。
我已经实现了两个模型和关联工作,我可以看到它显示在 postgres 服务器的 mi 数据库中。但是当我尝试实现我的校园请求时,我尝试包含经理信息,但没有成功。我不断收到同样的错误:
SequelizeEagerLoadingError: academic_manager is not associated to campus!
const campus = (sequelize, DataTypes) =>{
const Campus = sequelize.define('campus', {
name: {
type: DataTypes.STRING,
allowNull: false,
},
manager: {
type: DataTypes.INTEGER,
allowNull: false,
references: {
model: 'academic_manager',
key: 'id'
}
}
});
Campus.associate = models => {
Campus.hasOne(models.Manager, { foreignKey: 'id'});
}
return Campus;
};
export default campus;
const manager = (sequelize, DataTypes) =>{
const Manager = sequelize.define('academic_manager', {
name: {
type: DataTypes.STRING,
allowNull: false,
},
email: {
type: DataTypes.STRING,
allowNull: false
}
});
Manager.associate = models => {
Manager.belongsTo(models.Campus, { foreignKey: 'id'});
}
return Manager;
};
export default manager;
router.get('/', async (req, res) => {
const campus = await req.context.models.Campus.findAll({
include: [
{ model: req.context.models.Manager }
]
});
return res.send(campus);
});
TABLE "campus" CONSTRAINT "campus_manager_fkey" FOREIGN KEY (manager) REFERENCES academic_manager(id)
最佳答案
您的模型定义有几个问题。 Sequelize 可能会对您是否想要 感到困惑同事 模型,或者只是拥有它们 引用 彼此。
您添加了实现关系约束的关联,但还添加了引用键,这意味着允许引用但不实现约束。
可能想阅读:
const Campus = (sequelize, DataTypes) =>{
const Campus = sequelize.define('Campus', {
name: {
type: DataTypes.STRING,
allowNull: false,
}
// this is not correct.
// read when to use reference key further below
/* manager: {
type: DataTypes.INTEGER,
allowNull: false,
references: {
model: 'academic_manager',
key: 'id'
}
} */
});
Campus.associate = models => {
// Campus.hasOne(models.Manager, { foreignKey: 'id'});
// foreignKey `id` is wrong. Your models already by default have `id`, which is their own.
// you either define the name as `campus_id`, or just let sequelize handle it for you by not defining it at all and just use `Campus.hasOne(models.Manager)`.
// but generally it's good practice to define, otherwise when you need it, you have to figure out what did sequelize help you name it as.
// read: https://sequelize.org/master/manual/assocs.html#providing-the-foreign-key-name-directly
Campus.hasOne(models.Manager, { foreignKey: 'campus_id'); // this means please inject `campus_id` into `Manager`
}
return Campus;
};
export default Campus;
const Manager = (sequelize, DataTypes) =>{
const Manager = sequelize.define('Manager', {
name: {
type: DataTypes.STRING,
allowNull: false,
},
email: {
type: DataTypes.STRING,
allowNull: false
}
});
Manager.associate = models => {
// you don't define foreignKey here. because by doing so you are saying
// you want to inject this foreignKey into `Campus`, which you are not.
Manager.belongsTo(models.Campus);
}
return Manager;
};
export default Manager;
Location
Campus.hasOne(Manager)
Manager.belongsTo(Campus)
Location.hasOne(Campus)
Location.belongsTo(Campus)
Manager
留在
Campus
,你可以找到他们的
Location
像这样
Manager -> Campus -> Location
Manager
是真实的陈述。将永远留在那个
Location
没有其他地方,并且您的应用程序更频繁地需要此信息,您会很想这样做:
Location.hasOne(Manager)
Manager.belongsTo(Location)
Location -> Manager
,你完成了
Location -> Manager -> Campus -> Location -> Manager....
的循环引用
Location
之间的关系似乎是和
Manager
不是那么重要,然后继续使用
Manager -> Campus -> Location
.
constraints: false
.阅读
https://sequelize.org/master/manual/constraints-and-circularities.html
constraints: false
是我通常的选择,因为它仍然为我提供了所有的 Sequelize 方法,就好像模型是关联的一样。但要非常严格,您有权使用
reference keys
最多。然后进行手动连接,或使用您找到的引用键进行 2 次查询以在其引用表上定位其数据。
关于node.js - SequelizeEagerLoadingError : model is not associated to otherModel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61845632/
我对 mongoosejs 中模型的使用感到有些困惑。 可以通过这些方式使用 mongoose 创建模型 使用 Mongoose var mongoose = require('mongoose');
我正在看 from django.db import models class Publisher(models.Model): name = models.CharField(max_len
我有自己的 html 帮助器扩展,我用这种方式 model.Reason_ID, Register.PurchaseReason) %> 这样声明的。 public static MvcHtmlS
假设模型原本是存储在CPU上的,然后我想把它移到GPU0上,那么我可以这样做: device = torch.device('cuda:0') model = model.to(device) # o
我过去读过一些关于模型的 MVC 建议,指出不应为域和 View 重用相同的模型对象;但我找不到任何人愿意讨论为什么这很糟糕。 我认为创建两个单独的模型 - 一个用于域,一个用于 View - 然后在
我正在使用pytorch构建一个像VGG16这样的简单模型,并且我已经重载了函数forward在我的模型中。 我发现每个人都倾向于使用 model(input)得到输出而不是 model.forwar
tf.keras API 中的 models 是否多余?对于某些情况,即使不使用 models,代码也能正常运行。 keras.models.sequential 和 keras.sequential
当我尝试使用 docker 镜像运行 docker 容器时遇到问题:tensorflow/serving。 我运行命令: docker run --name=tf_serving -it tensor
我有一个模型,我用管道注册了它: register_step = PythonScriptStep(name = "Register Model",
如果 View 需要访问模型中的数据,您是否认为 Controller 应: a)将模型传递给 View b)将模型的数据传递给 View c)都不;这不应该是 Controller 所关心的。让 V
我正在寻找一个可以在模型中定义的字段,该字段本质上是一个列表,因为它将用于存储多个字符串值。显然CharField不能使用。 最佳答案 您正在描述一种多对一的关系。这应该通过一个额外的 Model 进
我最近了解了 Django 中的模型继承。我使用很棒的包 django-model-utils 取得了巨大的成功。我继承自 TimeStampedModel 和 SoftDeletableModel。
我正在使用基于 resnet50 的双输出模型进行项目。一个输出用于回归任务,第二个输出用于分类任务。 我的主要问题是关于模型评估。在训练期间,我在验证集的两个输出上都取得了不错的结果: - 综合损失
我是keras的新手。现在,我将使用我使用 model.fit_generator 训练的模型来预测测试图像组。我可以使用 model.predict 吗?不确定如何使用model.predict_g
在 MVC 应用程序中,我加入了多个表并将其从 Controller 返回到 View,如下所示: | EmployeeID | ControlID | DoorAddress | DoorID |
我在使用 sails-cassandra 连接系统的 Sails 中有一个 Data 模型。数据。 Data.count({...}).exec() 返回 1,但 Data.find({...}).e
我正在使用 PrimeFaces dataTable 开发一个 jsf 页面来显示用户列表。用户存储在 Model.User 类的对象中。
我正在关注https://www.tensorflow.org/tutorials/keras/basic_classification解决 Kaggle 挑战。 但是,我不明白应该将什么样的数据输入
我是这个领域的新手。那么,你们能帮忙如何为 CNN 创建 .config 文件吗? 传递有关如何执行此操作的文档或教程将对我有很大帮助。谢谢大家。 最佳答案 这个问题对我来说没有多大意义,因为 .co
我是“物理系统建模”主题的新手。我阅读了一些基础文献,并在 Modelica 和 Simulink/Simscape 中做了一些教程。我想问你,如果我对以下内容理解正确: 符号操作是将微分代数方程组(
我是一名优秀的程序员,十分优秀!