sql >> Databasteknik >  >> NoSQL >> MongoDB

Varför kommer inte mina refs att fylla i dokument?

Jag testar bara dina exempelkoder med följande, den här frågan Like.findOne({}).populate('user_id').exec(callback); verkar fungera bra.

Schema:

var PersonSchema = new mongoose.Schema({
    t: String
}, {collection: 'persons'});

var User = mongoose.model('User', PersonSchema.extend({
  _id: String,
  name: String
}));

var ParentSchema = new mongoose.Schema({
    s: String
}, {collection: 'parent'});

var Like = mongoose.model('Like', ParentSchema.extend({
  _id: String,
  user_id: {
    type: String,
    ref: 'User'
  }
}));

Infoga data i DB,

var user = new User({
    t: 't1',
    _id: '1234567',
    name: 'test'
});

var like = new Like({
    s: 's1',
    _id: '23456789',
});

user.save(function(err, u){
    if(err)
        console.log(err);
    else {
        like.user_id = u._id;
        console.log(like);
        like.save(function(err) {
            if (err)
                console.log(err);
            else
                console.log('save like and user....');
        });
    }
});

Fråga av

Like.findOne({}).populate('user_id').exec(function(err, doc) {
    if (err)
        console.log(err);
    else
        console.log(doc);
});

Och resultatet är

{ _id: '23456789',
  __t: 'Like',
  user_id: { _id: '1234567', __t: 'User', t: 't1', name: 'test', __v: 0 },
  s: 's1',
  __v: 0 }



  1. Hur kan jag fjärrinspektera data i mina RedisCloud DB:er?

  2. Vad är namnkonventioner för MongoDB?

  3. Konvertering från String till MongoDB ObjectID

  4. MongoDB Query, sortera och ta sedan n:te dokumentet för grupp