gpt4 book ai didi

node.js - 通过 ObjectId 查询 Mongoose Schema

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

再次需要你的帮助,希望对于这个项目,我在这里得到的答案将是最后一个。我已经看到这是一个相当常见的问题,但我已经在另一个 Stack Overflow post 上尝试了提示, 一个来自 Google Group ,但这些解决方案对我没有用。

我的代码有点像:

mongoose = require('mongoose');
Schema = mongoose.Schema;
mongoose.connect(MONGO_SERVER);
ObjectId = Schema.ObjectId;

var RacesSchema = new Schema({
venue_id : { type: mongoose.Schema.ObjectId, ref: 'Venues' },
racetype : String
});
var races = mongoose.model('Races', RacesSchema );

function test() {
var MyObjectId = require('mongoose').Types.ObjectId;
queryVenue = new MyObjectId("50e3dcdbf30375180c078f64");

races.find({venue_id: queryVenue, racetype:'Test'})
.exec(function(err,data) {
}

test();

但我没有得到结果,我知道有结果。

非常感谢!

更新

已将上述代码示例最小化,如果我自己查询字符串值,则此测试有效,只是查询 ObjectId 是失败的地方,而且我知道它存在。

JSON 更新

这是我要找的:

{
"_id" : ObjectId("50e3dcddf30375180c078f85"),
"venue_id" : "50e3dcdbf30375180c078f64",
"racetype" : "A"
}

突然之间,我相信我的答案对我来说变得清晰了。仅仅是因为 venue_id 实际上是一个字符串吗?如果是这样,我可以保持我的 mongoose 模式不变,并在查找字符串时对查询进行强制转换吗?或者我是否应该更改这些值的存储方式(来 self 开发的单独的 .net 应用程序)以作为 ObjectId 插入?

目前对于另一个查询,当前 Mongoose 模式和数据库[实际设置]的方式,使用 populate() 可以很好地用这个模型的方式填充引用表 (venue_id) 的结果当前设置,唯一不同的是上面的查询,我没有指定 venue_id ...

谢谢。

最佳答案

是的,问题的发生是因为架构 (ObjectId) 中 venue_id 的数据类型与文档 (String) 中的数据类型不匹配。所以 find 正在寻找 ObjectId 值,但没有找到匹配项,因为它是文档中的字符串。

解决此问题的正确方法是编写一个小程序来将文档中的 venue_id 值更新为 ObjectId 而不是字符串,然后您的查询就会起作用。这也会将这些字段的大小从 24 字节缩小到 12。

关于node.js - 通过 ObjectId 查询 Mongoose Schema,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15003010/

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