MongoDB练习题(尚硅谷)

这篇博客详细介绍了MongoDB数据库的使用,包括连接数据库、插入、查询、更新和删除文档,以及内嵌文档的操作,如添加、修改和查询。此外,还涉及到批量插入、条件查询、分页查询和集合管理等高级操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.进入my_test数据库

use my_test

2.向数据库的user集合中插入一个文档  

db.users.insert({
    username:"sunwukong"
});

3.查询user集合中的文档

db.users.find();

4.向数据库的user集合中插入一个文档   

db.users.insert({
    username:"zhubajie"
});

  5.查询数据库user集合中的文档

db.users.find();

6.统计数据库user集合中的文档数量

db.users.find().count();

7.查询数据库user集合中username为sunwukong的文档

db.users.find({username:"sunwukong"});

8.向数据库user集合中的username为sunwukong的文档,添加一个address属性,属性值为huaguoshan

db.users.update({username:"sunwukong"},{$set:{address:"huaguoshan"}});

9.使用{username:"tangseng"} 替换 username 为 zhubajie的文档

db.users.replaceOne({username:"zhubajie"},{username:"tangseng"});  

10.删除username为sunwukong的文档的address属性

db.users.update({username:"sunwukong"},{$unset:{address:1}});

11.向username为sunwukong的文档中,添加一个hobby:{cities:["beijing","shanghai","shenzhen"] , movies:["sanguo","hero"]}
      MongoDB的文档的属性值也可以是一个文档,当一个文档的属性值是一个文档时,我们称这个文档叫做 内嵌文档

db.users.update({username:"sunwukong"},{$set:{hobby:{cities:
["beijing","shanghai","shenzhen"] , movies:["sanguo","hero"]}}});

db.users.find();

12.向username为tangseng的文档中,添加一个hobby:{movies:["A Chinese Odyssey","King of comedy"]}

db.users.update({username:"tangseng"},{$set:{hobby:
{movies:["A Chinese Odyssey","King of comedy"]}}})

13.查询喜欢电影hero的文档
   MongoDB支持直接通过内嵌文档的属性进行查询,如果要查询内嵌文档则可以通过.的形式来匹配
      如果要通过内嵌文档来对文档进行查询,此时属性名必须使用引号 

db.users.find({'hobby.movies':"hero"});

  14.向tangseng中添加一个新的电影Interstellar
      $push 用于向数组中添加一个新的元素
      $addToSet 向数组中添加一个新元素 , 如果数组中已经存在了该元素,则不会添加

db.users.update({username:"tangseng"},{$push:{"hobby.movies":"Interstellar"}});
db.users.update({username:"tangseng"},{$addToSet:{"hobby.movies":"Interstellar"}});
db.users.find();

15.删除喜欢beijing的用户

db.users.remove({"hobby.cities":"beijing"});

16.删除user集合

db.users.remove({});
db.users.drop();
show dbs;

17.向numbers中插入20000条数据 7.2s

for(var i=1 ; i<=20000 ; i++){
    db.numbers.insert({num:i});
}
db.numbers.find()
db.numbers.remove({});

//0.4s

var arr = [];
for(var i=1 ; i<=20000 ; i++){
    arr.push({num:i});
}
db.numbers.insert(arr);

 18.查询numbers中num为500的文档

db.numbers.find({num:500})

 19.查询numbers中num大于5000的文档

db.numbers.find({num:{$gt:500}});
db.numbers.find({num:{$eq:500}});

 20.查询numbers中num小于30的文档

db.numbers.find({num:{$lt:30}});

 21.查询numbers中num大于40小于50的文档

db.numbers.find({num:{$gt:40 , $lt:50}});

 22.查询numbers中num大于19996的文档

db.numbers.find({num:{$gt:19996}});

 23.查看numbers集合中的前10条数据

db.numbers.find({num:{$lte:10}});

//limit()设置显示数据的上限

db.numbers.find().limit(10);

//在开发时,我们绝对不会执行不带条件的查询
db.numbers.find();

 24.查看numbers集合中的第11条到20条数据

    分页 每页显示10条
        1-10     0
        11-20    10
        21-30    20
        。。。
        
        skip((页码-1) * 每页显示的条数).limit(每页显示的条数);
        
    skip()用于跳过指定数量的数据    
    
    MongoDB会自动调整skip和limit的位置

db.numbers.find().skip(10).limit(10);

 25.查看numbers集合中的第21条到30条数据

db.numbers.find().skip(20).limit(10);
db.numbers.find().limit(10).skip(10);

 26.将dept和emp集合导入到数据库中

db.dept.find()
db.emp.find()

 27.查询工资小于2000的员工

db.emp.find({sal:{$lt:2000}});

 28.查询工资在1000-2000之间的员工

db.emp.find({sal:{$lt:2000 , $gt:1000}});

 29.查询工资小于1000或大于2500的员工

db.emp.find({$or:[{sal:{$lt:1000}} , {sal:{$gt:2500}}]});

 30.查询财务部的所有员工

//(depno)
var depno = db.dept.findOne({dname:"财务部"}).deptno;
db.emp.find({depno:depno});

 31.查询销售部的所有员工

var depno = db.dept.findOne({dname:"销售部"}).deptno;
db.emp.find({depno:depno});

 32.查询所有mgr为7698的所有员工

db.emp.find({mgr:7698})

 33.为所有薪资低于1000的员工增加工资400元

db.emp.updateMany({sal:{$lte:1000}} , {$inc:{sal:400}});
db.emp.find()
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值