MongoDB第二节课作业
配置环境变量后,命令行输入:mongo
//1.进入my_test数据库
show dbs;
use my_test;
show collections;
//2.向数据库的user集合中插入一个usename为deer的文档
//3.查询user集合中的文档
//4.向数据库的user集合中插入一个usename为james的文档
//5.查询数据库user集合中的文档
//6.统计数据库user集合中的文档数量
db.user.find({}).size();
//7.查询数据库user集合中username为deer的文档
//8.向数据库user集合中的username为deer的文档,添加一个address属性,属性值为changsha
db.user.updateMany({"username":"deer"},{$set:{"address":"changsha"}});
//9.使用{username:"peter"} 替换 username 为 james的文档
db.user.updateMany({"username":"peter"},{$set:{"username":"james"}});
// 根据ID更新
db.user.updateMany({"_id":ObjectId('5e01a02ff1cad35b9f123e74')},{$set:{"username":"peter"}});
//10.删除username为deer的文档的address属性
db.user.updateMany({"username":"deer"},{$unset:{"address":1}});
//11.向username为deer的文档中,添加一个hobby:{cities:["beijing","shanghai","shenzhen"] , movies:["djr","huluwa"]}
db.user.updateMany({"username":"deer"},{$set:{"hobby":{"citys":["beijing","shanghai","shenzhen"],movies:["djr","huluwa"]}}})
//12.向username为peter的文档中,添加一个hobby:{movies:["king of china","yiluxiangxi"]}
db.user.updateMany({"username":"peter"},{$set:{"hobby":{movies:["king of china", "yiluxiangxi"]}}});
//13.查询喜欢电影djr的文档
db.user.find({"hobby.movies":"djr"}).pretty();
//13.1查询 喜欢djr 和hulw的文档
db.user.find({"hobby.movies":{"$all":["djr", "huluwa"]}}).pretty();
注意,如果这里用all,则为喜欢djr和huluwa的,同一条记录里必须都有djr和huluwa
db.user.find({"hobby.movies":{"$in":["djr", "huluwa"]}}).pretty();
用$in,记录中只要有djr或者有huluwa的,都会被查询出
//13.2查询 喜欢djr 或hulw的文档
db.user.find({"hobby.movies":{"$in":["djr", "yiluxiangxi"]}}).pretty();
db.user.find({"$or":[{"hobby.movies":"djr"}, {"hobby.movies":"yiluxiangxi"}]});
结果一样
//14.向peter中添加一个新的电影jpm
以下两个方法结果一致
db.user.updateMany({"username":"peter"},{"$addToSet":{"hobby.movies":{"$each":["jpm"]}}});
db.user.updateMany({"username":"peter"},{"$addToSet":{"hobby.movies":"jpm"}});
会导致在jpm本身应在的位置变成一个数组:
db.user.updateMany({"username":"peter"},{"$addToSet":{"hobby.movies":["jpm"]}});
//15.删除喜欢beijing的用户
db.user.deleteMany({"hobby.citys":{"$in":["beijing"]}});
//16.删除user集合
db.user.drop();
//17.向persons中插入20000条数据
//18.查询persons中num为500的文档
//19.查询persons中num大于5000的文档
//20.查询persons中num小于30的文档
//21.查询persons中num大于40小于50的文档
//22.查询persons中num大于19996的文档
//23.查看persons集合中的前10条数据
//24.查看persons集合中的第11条到20条数据
//25.查看persons集合中的第21条到30条数据