Sails.js获取多对多关联计数

8

我有一个模型(用户),它与另一个模型(电话)关联。这种关联是多对多的。以下调用已经内置在Sails中,它允许我获取特定用户的所有电话记录:

GET - /user/:userId/phones

我希望能在这个调用中实现分页,但是无法弄清楚如何获取结果的总数。我尝试过覆盖蓝图中的find.js和/或findOne.js以返回计数,但上述调用似乎没有运行该逻辑。

1个回答

9

非常好的问题。Sails使用“join”模型来实现多对多关联。它不会出现在您的api/models文件夹中,但如果需要,仍然可以查询它。在您的情况下,它可能是这样的:

sails.models['user_phones__phone_users'].count({user_phones: userId}).exec(...)

确切的模型名称取决于您的模型及其 via 键;找出最简单的方法是运行 sails console 并执行以下操作:

sails.util.keys(sails.models)

列出系统中的所有模型。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接