sql >> Database teknologi >  >> NoSQL >> MongoDB

Mongoose udløber data, men beholder i databasen

Du bør bruge konceptet Skema Reference for det. Gem din udløbne felt i en anden tabel og tilmeld dig din primære user_table og expire_table (wxample name)

var UserSchema = new Schema({
    name: String,
    email: String
});

//save date by-default
//expire in 1 min as in your example
var expireSchema = new Schema({
    createdAt: { type: Date, default: Date.now, expires: '1m'  },
    user_pk: { type: Schema.Types.ObjectId, ref: 'user_expire'}
});

var userTable = mongoose.model('user_expire', UserSchema);
var expireTable = mongoose.model('expireMe', expireSchema);

//Save new user
var newUser =  new userTable({
    name: 'my_name',
    email: 'my_email'
});

newUser.save(function(err, result) {
    console.log(result, 'saved')
    var newExpire =  new expireTable({
        user_pk:result._id
    });
    //use _id of new user and save it to expire table
    newExpire.save(function(err, result) {
        console.log('saved relation')
    })
})

Nu for at registrere, om sessionen er udløbet eller ej

1. på at udføre denne kode, før data udløber

expireTable.findOne()
.populate('user_pk')
.exec(function (err, result) {
    if (err) throw err;
    console.log(result)
    if(result == null) {
        console.log('session has expired, renew session')
    } else {
        console.log('session is active')
    }
});

//output - session is active

2. på at udføre denne kode efter data er udløbet

expireTable.findOne()
.populate('user_pk')
.exec(function (err, result) {
    if (err) throw err;
    console.log(result)
    if(result == null) {
        console.log('session has expired, renew session')
    } else {
        console.log('session is active')
    }
});

//output - session has expired, renew session


  1. Gør en sum med mongo db aggregeringsramme

  2. Node.JS objektprototype må kun være et objekt eller null med Redis

  3. HBase BlockCache 101

  4. importerer JSON til mongoDB ved hjælp af pymongo