MongoDB中常用语句

栏目: 数据库 · 发布时间: 5年前

内容简介:有时候用户删除操作的时候,需求是这样的,仅是隐藏这条数据,并不是真的从数据库中删除。 这时候就用到假删除了, 比如这个是张三发的两篇微博:用户增加两条数据,但只保留后一条,删除前一条,这时候用到假删除 ,在添加数据时加上一个字段是表示用户没有删除 为1是表示用户已经删除

delete()删除

db.collection.deleteOne()
db.collection.deletMany();

remove()删除

db.student.remove({name:"李四"});
db.student.remove({sex:"男"},true);
db.student.remove({});

数据库假删除

有时候用户删除操作的时候,需求是这样的,仅是隐藏这条数据,并不是真的从数据库中删除。 这时候就用到假删除了, 比如这个是张三发的两篇微博:

db.student.insert([
    {name:"张三",content:"今天心情好",isDel:0},
    {name:"张三",content:"今天心情一般",isDel:0},
]);
复制代码
MongoDB中常用语句

用户增加两条数据,但只保留后一条,删除前一条,这时候用到假删除 ,在添加数据时加上一个字段 isDel:0
所以当用户删除数据时候 执行的不是remove方法而是update方法

db.student.update({"_id" : ObjectId("5bd6a46f1eb7a22fa07cb382")},{
    $set:{
      isDel:1
    }
});
复制代码
MongoDB中常用语句
isDel:0

是表示用户没有删除 为1是表示用户已经删除

所以在查询的时候要筛选name和isDel条件即可

db.student.find({name:"张三",isDel:0});
复制代码

查询到用户没有删除的数据:

MongoDB中常用语句

然后就可以实现假删除了。

批量数据的操作和修改

  1. 向集合中插入10000个文档
var arr= [];
for(var i=0;i<10000;i++){
   arr.push({counter:i});
}
db.demos.insert(arr);
db.demos.find();
复制代码
db.demos.find({counter:666});
db.demos.find({counter:{$lt:666}});
db.demos.find({counter:{$gt:666}});
db.demos.find({counter:{$gt:66, $lt:666}});
db.demos.find().limit(10);
db.demos.find().skip(0).limit(10);//第一页 从0条开始 每查询10条
db.demos.find().skip(10).limit(10);//第二页 从10条开始 每查询10条
db.demos.find().skip(20).limit(10);//第三页 从20条开始 每查询10条

复制代码

集合中文档关系

  1. 一对一(noe to noe): 比如:人和身份证 老公和老婆
  2. 一对多(noe to many): 比如:父母和孩子 用户和物品
  3. 多对多(many to many): 比如:老师和学生

一对一

以内嵌文档的形式体现,

//一对一
db.aAndb.insert([
 {name:"杨过",wife:{name:"小龙女",sex:"女"},sex:"男"},
  {name:"杨过",wife:{name:"小龙女",sex:"女"},sex:"男"}
])

db.aAndb.find();
复制代码

一对多

通过内嵌文档的形式实现或者通过集合的形式实现

//一对多  比如  微博 和 微博评论
//添加微博
db.weibo.insert([
{weibo:"世界这么大,我想去看看"},
{weibo:"我要做一名web开发者!!!"}
])

db.weibo.find();
复制代码

添加评论

db.comments.insert([
{
weibo_id: ObjectId("5bdd89e06a5e78f4cfc2b9c8"),
list:[
   "那你有钱吗",
    "一个人吗??去呢啊??",
    "加油!!"
]
},
{
weibo_id: ObjectId("5bdd89e06a5e78f4cfc2b9c9"),
list:[
   "那你要学习HTML",
   "那还要你要学习css",
    "加油!!"
]
}
]);

db.comments.find();
复制代码

查询一对多

var weibo_id= db.weibo.findOne({"weibo" : "世界这么大,我想去看看"})._id;
db.comments.find({weibo_id: weibo_id});
复制代码

多对多的关系

比如:学生和老师 可以通过多文档关联,

//多对多  老师《------》学生

//插入老师集合
db.teachers.insert([
{
  name:"语文老师",
  teacher_id: 1,
  student_id:[
     1001,
     1002,
     1003
  ]
  },
{
  name:"数学老师",
  teacher_id: 2,
  student_id:[
     1001,
     1002,
     1003
  ]
  },
{
  name:"英语老师",
  teacher_id: 3,
  student_id:[
     1001,
     1002,
     1003
  ]
 }
])

db.teachers.find();


//插入学生集合
db.students.insert([
{
  name:"小明",
  student_id: 1001,
  teacher_id:[
     1,
     2,
     3
  ]
  },
{
  name:"小红",
  student_id: 1002,
  teacher_id:[
     1,
     2,
     3
  ]
  },
{
  name:"小刚",
  student_id: 1003,
  teacher_id:[
     1,
     2,
     3
  ]
 }
])

db.students.find();
db.teachers.find();
复制代码

排序和索引

排序:

查询文档时,默认是按照_id的值进行 排序 的(升序) sort() 可以用来指定文档的排序规则,sort() 内部需要传递一个对象来指定文档的排序规则 ,其中1表示升序 ,-1表示降序 limit skip sort 的顺序可以任意改变 ,运行时会自动调整。 不希望它默认按照id排序 希望它按照工资来排序

//按照工资升序排列

db.section.find().sort({wages:1});

//优先按照工资升序排列  如果遇到相同的就在  按照id升序排列
db.section.find().sort({wages: 1},{_id: -1});

复制代码

索引:

展示字段中 部分内容 或者是提取这个字段内的部分内容 在查询时 ,可以在第二个参数来设置查询的结果投影

索引: find({ 查询条件 }, { 检索范围(1显示 0隐藏)}) 注意: _id 如果不设置默认是1(显示) 可手动隐藏

db.section.find({}, {name: 1});

//只显示name和wages字段
`db.section.find({}, {name: 1, _id: 0, wages: 1});`
复制代码
MongoDB中常用语句

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Just My Type

Just My Type

Simon Garfield / Profile Books / 2010-10-21 / GBP 14.99

What's your type? Suddenly everyone's obsessed with fonts. Whether you're enraged by Ikea's Verdanagate, want to know what the Beach Boys have in common with easy Jet or why it's okay to like Comic Sa......一起来看看 《Just My Type》 这本书的介绍吧!

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

html转js在线工具
html转js在线工具

html转js在线工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具