gpt4 book ai didi

javascript - Strongloop 环回 : Filter by id of related Model

转载 作者:搜寻专家 更新时间:2023-10-31 23:17:38 25 4
gpt4 key购买 nike

我有一个带有一些模型和关系的 Strongloop Loopback Node.js 项目。

手头的问题

我的问题涉及如何只查询那些 Media与某个 Tag 有关系的实例id,使用 Angular SDK - 同时查询Tags.media (返回 Tag 实例),而是以某种方式进行查询,返回普通 Media实例。

请阅读下面的具体信息..

规范

基本上,我有一个模型 Media其中有许多“标签”(型号 Tag )。想象一个图像文件 ( Media ) 具有各种 EXIF 标签 ( Tag )。这是关系规范(这一切都按预期工作):

媒体(media.json):

{
"name": "media",
"base": "PersistedModel",
"properties": {
"id": {
"type": "string",
"id": true
}
},
"relations": {
"tags": {
"type": "hasAndBelongsToMany",
"model": "tag"
}
}

标签(tag.json):

{
"name": "tag",
"base": "PersistedModel",
"idInjection": true,
"properties": {
"name": {
"type": "string",
"required": true
}
},
"relations": {
"medias": {
"type": "hasAndBelongsToMany",
"model": "media"
}
},
"acls": [],
"methods": []
}

解决方案

现在,我知道我可以执行这样的查询(在我的示例中使用 Angular SDK,但语法是相同的):

injector.get('Tag').find({
'filter': {
'include': 'medias',
'where': {'id': <mytagid>}
}
});

我对这种方法的问题是,我收到 1 ( one ) Tag附有 Media 的实例实例。这打乱了为什么我只处理 Media 的整个工作流程实例.. 我只想按 Tag 过滤 id,不用管Tag完全没有。

底线

如果我看到 API 浏览器 ( /explorer/ ),返回值 GET /api/tags/<myTagID>/medias正是我需要的 - Media 的数组对象 - 但如何使用 Angular SDK (lb_services) 完全像这样查询它们?

最佳答案

我遇到了类似的问题。一个建议是打开 lb-services.js 并尝试查找:/tags/:id/medias 或类似的东西。然后你会发现这样的评论://INTERNAL。请改用 Tags.medias()。 或类似的东西。这就是您应该调用的方法。不要调用“prototype$__get.....”方法。

然后就按照我想的那样调用:Tag.medias({id:})

其他建议:

正如您在描述中所说,媒体有很多标签。那么为什么不使用

{
"name": "media",
"base": "PersistedModel",
"properties": {
"id": {
"type": "string",
"id": true
}
},
"relations": {
"tags": {
"type": "hasMany", <---------- hasMany
"model": "tag",
"foreignKey": "tagId" <---FK name
}
}

和对于标签只是 belongsTo 作为类型。

{
"name": "tag",
"base": "PersistedModel",
"idInjection": true,
"properties": {
"name": {
"type": "string",
"required": true
}
},
"relations": {
"medias": {
"type": "belongsTo",
"model": "media",
"foreignKey": "mediaId" <---FK name
}
},
"acls": [],
"methods": []
}

但我真的不认为这是问题所在,因为您在请求 GET /api/tags/<myTagID>/medias 时说过它返回你想要的。

然后,在 AngularJS 中你可以使用:

 Media.tags({id:<mediaId>})

对于媒体/:id/标签

另一边试试:

Tag.medias({id:<tagId>})


Tag.find({
filter:{
where:{mediaId: <mediaId>} <----mediaId comes from FK name
}
})

在这种情况下,两者都是持久模型,没有问题,我在对扩展用户类型的数据做类似的事情时遇到了权限问题。但那是另一回事了……

希望这对您有所帮助,我从我正在做的一个类似应用程序中更改了一些东西,希望在适应您的代码时不会犯太多错误...

关于javascript - Strongloop 环回 : Filter by id of related Model,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28914081/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com