MongoDB
 sql >> Teknologi Basis Data >  >> NoSQL >> MongoDB

Data kedaluwarsa luwak tetapi tetap di database

Anda harus menggunakan konsep Referensi Skema untuk ini. Simpan kedaluwarsa . Anda bidang di tabel lain dan bergabung dengan user_table utama Anda dan expire_table (nama contoh)

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')
    })
})

Sekarang untuk mendeteksi apakah sesi telah kedaluwarsa atau belum

1. saat mengeksekusi kode ini sebelum data kedaluwarsa

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. saat mengeksekusi kode ini setelah data kedaluwarsa

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. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Periksa apakah ada nilai dalam koleksi mongo

  2. kesalahan:definisi kelas atau objek yang diharapkan

  3. MongoDB:Permintaan lambat, bahkan dengan indeks

  4. Objek Tersemat MongoDB tidak memiliki ID (nilai nol)

  5. Nama bidang FieldPath tidak boleh berisi '.' di $grup