当我们向数据库中导入数据后,有时候需要删除数据。下面是对MongoDB数据库中删除文档的整理,希望可以帮助到有需要的小伙伴~
删除文档
findOneAndDelete方法 - 删除一条文档
查找到一条文档并且删除
返回结果是你删除的文档
如果查询条件匹配了多个文档,将会删除第一个匹配的文档
示例:
const mongoose = require('mongoose');
// 对于没有创建的数据库,会自动创建一个数据库
mongoose.connect('mongodb://localhost/playground',{useNewUrlParser: true,useUnifiedTopology: true})
.then(() => console.log('数据库连接成功'))
.catch(err => console.log(err,'数据库连接失败'))
// 创建集合规则 mongoose.Schema
const userSchema = new mongoose.Schema({
// 字段: 类型
name: String,
age: Number,
email:String,
password:String,
hobbies:[String]
});
// 使用规则创建集合
const User = mongoose.model('User',userSchema);
// 查找到一条文档并且删除
// 返回结果是你删除的文档
// 如果查询条件匹配了多个文档,将会删除第一个匹配的文档
// 知道id为5ff2e0ee6bf9ce573f0df41e的文档并删除,返回结果是id为5ff2e0ee6bf9ce573f0df41e的文档
User.findOneAndDelete({_id:'5ff2e0ee6bf9ce573f0df41e'}).then(result => console.log(result))
回到MongoDB图形化工具中刷新后,会发现该文档被删除了
deleteMany方法 - 删除多条文档
const mongoose = require('mongoose');
// 对于没有创建的数据库,会自动创建一个数据库
mongoose.connect('mongodb://localhost/playground',{useNewUrlParser: true,useUnifiedTopology: true})
.then(() => console.log('数据库连接成功'))
.catch(err => console.log(err,'数据库连接失败'))
// 创建集合规则 mongoose.Schema
const userSchema = new mongoose.Schema({
// 字段: 类型
name: String,
age: Number,
email:String,
password:String,
hobbies:[String]
});
// 使用规则创建集合
const User = mongoose.model('User',userSchema);
// 查找到一条文档并且删除
// 返回结果是你删除的文档
// 如果查询条件匹配了多个文档,将会删除第一个匹配的文档
// 找到id为5ff2e0ee6bf9ce573f0df41e的文档并删除,返回结果是id为5ff2e0ee6bf9ce573f0df41e的文档
// User.findOneAndDelete({_id:'5ff2e0ee6bf9ce573f0df41e'}).then(result => console.log(result))
// 删除多条文档
// 删除所有的文档
User.deleteMany({}).then(result => console.log(result));
回到 MongoDB中刷新,所有数据都没了。
end~