如果我有一个包含另一个实体的 1:n 集合的实体,那么保存集合的正确方法是什么?
我已经到了这个(代码尚未完成/检查):
return datacontext.savechanges([parentEntity]).then(function() {
for (var i=0;i < childArray.length;i++) {
var newChildEntity;
return datacontext.makeNewChildEntity(newChildEntity).then(function() {
newChildEntity.parentID(parentEntity().id());
...
//set other newChildEntity properties
...
return datacontext.savechanges([newChildEntity]).then(function() {
//set finished flag and exit function...
}
}
}
}
"datacontext"是一个异步模块,具有各种公开的方法,包括创建新的子实体。
虽然我还没有测试过这个,但它在逻辑上对我有用,但是对于我想添加到子实体集合中的每个新子对象,我在 createEntity/modifyEntity/saveEntity 循环中循环是对的吗? 这是唯一的方法,还是有办法一次性完成所有子实体?
"parentID"是一个身份字段 - 存储生成,因此我必须等待初始父保存完成,然后才能使用返回的 ID。
编辑以添加:我认为我不需要在异步 newChildEntity 保存的末尾有一个"然后",对吗? 我需要它仍然是异步的,这样它就可以快速关闭并遍历多个子实体,因为依赖位是已经生成的父记录中的 id。所有子记录共享相同的父 ID,因此我可以设置多个保存,而无需等待 saveChanges 方法响应,对吗?
> Breeze的EntityManager.saveChanges可以在一次调用中保存任意数量的实体,这比尝试为每个实体调用一次saveChanges要高得多。
另外,我不确定为什么你的makeNewChildEntity需要异步,Breeze的EntityManager.createEntity本身是同步的,所以我认为你需要做的就是这样的事情。
return datacontext.savechanges([parentEntity]).then(function() {
var listOfEntities = [parentEntity];
for (var i=0;i < childArray.length;i++) {
// synchronous makeNewChildEntity
var newChildEntity = datacontext.makeNewChildEntity();
newChildEntity.parentID(parentEntity().id());
...
//set other newChildEntity properties
...
listOfEntities.push(newChildEntity);
}
// alternatively use datacontext.savechanges(listOfEntities).then(...)
return datacontext.savechanges().then(function() {
//set finished flag and exit function...
}
}
}