猫鼬每天的独特价值

时间:2019-01-13 17:22:02

标签: node.js mongoose

我正在尝试配置猫鼬模式的唯一参数。我需要允许每天写给DB的唯一作者不超过一位。 Schema.index({author:1,created:1},{unique:true})不起作用,在这里我无法输入时间段。

有什么更好的方法来决定这种情况?

const Report = new Schema({
  author: {
    type: mongoose.Schema.Types.ObjectId,
    ref: 'DiscordUserList',
    required: true
  },
  reports: [{ reportNum: { type: Number }, text: { type: String }, date: { type: Date, default: Date.now } }],
  questionsDone: [{ questionNum: { type: Number }, done: { type: Boolean }, date: { type: Date, default: Date.now } }],
  created: {
    type: Date,
    default: Date.now
  }
}, { strict: false })
Report.plugin(mongoosePaginate)



const reportListSchema = mongoose.model('ReportList', Report)


module.exports = reportListSchema

1 个答案:

答案 0 :(得分:0)

您可以使用 $setOnInsert upsert选项进行更新操作,即如果update()upsert: true找到了匹配的文档,则MongoDB使用 $set 操作执行更新,但忽略 $setOnInsert 操作。因此,您的典型更新如下:

import moment from 'moment'

const start = moment().startOf('day').toDate() // set to 12:00 am today
const end = moment().endOf('day').toDate() // set to 23:59 pm today
ReportList.findOneAndUpdate(
    { 
        'author': author_id, 
        'created': { '$gte': start, '$lte': end }
    },
    {
        '$set': { 'author': author_id },
        '$setOnInsert': { 'created': moment().toDate() }
    },
    { 'upsert': true, 'new': true },
    (err, report) => {
        console.log(report)
    }
)

或使用setDefaultsOnInsert选项,当此选项和upsert为true时,如果创建了新文档,猫鼬将应用模型模式中指定的默认值:

ReportList.findOneAndUpdate(
    { 
        'author': author_id, 
        'created': { '$gte': start, '$lte': end }
    },
    { '$set': { 'author': author_id } },
    { 
        'upsert': true, 
        'new': true, 
        'setDefaultsOnInsert': true 
    },
    (err, report) => {
        console.log(report)
    }
)