This commit is contained in:
2025-10-29 18:27:53 +08:00
parent 23580470be
commit 4fa5dc4c90

68
src/moogoose/demo.js Normal file
View File

@@ -0,0 +1,68 @@
// models/DiaryEntry.js
const mongoose = require('mongoose');
const DiaryEntrySchema = new mongoose.Schema({
userId: {
type: mongoose.Schema.Types.ObjectId,
ref: 'User', // 关联用户(支持多用户)
required: true
},
title: {
type: String,
trim: true,
default: '无标题'
},
content: {
type: String,
required: true,
trim: true
},
date: {
type: Date,
default: Date.now,
index: true // 为日期建立索引,加速按日查询
},
tags: [{
type: String,
lowercase: true,
trim: true
}],
mood: {
type: Number,
min: 1,
max: 5,
default: 3, // 1=非常差5=非常好
index: true
},
weather: {
type: String,
enum: ['晴', '阴', '雨', '雪', '雾', '其他'],
default: '其他'
},
location: {
lat: Number,
lng: Number,
address: String
},
media: [{
type: String, // 图片/音频/视频 URL
trim: true
}],
createdAt: {
type: Date,
default: Date.now
},
updatedAt: {
type: Date,
default: Date.now
}
}, {
timestamps: true // 自动管理 createdAt / updatedAt
});
// 为常用查询建立复合索引
DiaryEntrySchema.index({ userId: 1, date: -1 }); // 按用户+日期降序(最新在前)
DiaryEntrySchema.index({ userId: 1, tags: 1 }); // 按标签查找
DiaryEntrySchema.index({ userId: 1, mood: 1 }); // 按情绪筛选
module.exports = mongoose.model('DiaryEntry', DiaryEntrySchema);