这是我的架构定义: var DocSchema = new mongoose.Schema({ _id: { name: String, path: String }, label: String, ...});mongoose.model('Doc', DocSchema, 'doc_parse_utf8');var Doc = mongoose.model('Doc'); 并且其他程序已将文件插入
var DocSchema = new mongoose.Schema({
_id: {
name: String,
path: String
},
label: String,
...
});
mongoose.model('Doc', DocSchema, 'doc_parse_utf8');
var Doc = mongoose.model('Doc');
并且其他程序已将文件插入到mongodb中.然后我试着查询文件:
Doc.findOne({_id:{name:name,path:path}}, function(err, doc){
if (err && err_handler) {
err_handler(err);
} else if(callback) {
callback(doc);
}
});
但是,将报告一个强制转换错误:
{ message: 'Cast to ObjectId failed for value "[object Object]" at path "_id"',
name: 'CastError',
type: 'ObjectId',
value: { name: 'mobile', path: 'etc/' },
path: '_id' }
我在mongoose的文档,google和statckoverflow.com上搜索过这个问题,然而,对我来说没有任何解决方案.请帮忙,谢谢.
您需要做的就是通过将_id类型设置为Mixed来覆盖它.var UserSchema = new Schema({
_id: Schema.Types.Mixed,
name: String
});
这导致Mongoose基本上忽略了对象的细节.
现在,当您使用find时,它将起作用(几乎与预期一样).
我警告你,你需要确定你正在使用的_id对象的属性顺序必须以完全相同的顺序提供,否则_ids不会被认为是相同的.
当我尝试这样做时:
var User = mongoose.model('User', UserSchema);
var testId = { name: 'wiredprairie', group: 'abc'};
var u = new User({_id: testId , name: 'aaron'});
u.save(function(err, results) {
User.find().where("_id", testId)
.exec(function(err, users) {
console.log(users.length);
});
});
控制台输出为0.
我注意到MongoDB中的实际数据存储方式与我认为保存的方式不同:
{
"_id" : {
"group" : "abc",
"name" : "wiredprairie"
},
"name" : "aaron",
"__v" : 0
}
正如你所看到的那样,它不是名字,而是我编码的组. (这是按字母顺序排列的,回想起来有意义).
所以,相反,我这样做了:
var User = mongoose.model('User', UserSchema);
var testId = { name: 'wiredprairie', group: 'abc'};
var u = new User({_id: testId , name: 'aaron'});
u.save(function(err, results) {
User.find().where("_id", { group: 'abc', name: 'wiredprairie'})
.exec(function(err, users) {
console.log(users.length);
});
});
然后,控制台输出为1.
