一句话解释:MongoDB是一个基于分布式文件存储的数据库。 由C++编写。旨在为web程序提供可扩展性高的高性能的数据存储解决方案
非关系数据库和关系型数据库的区别是什么?
- 实质:非关系型数据库的实质:非关系型数据库产品是传统关系型数据库的功能阉割版,通过减少用不到或很少用的功能,来大幅度提高产品性能。
- 价格:目前的非关系型数据库基本都是免费的,而比较有名气的关系型数据库都是收费的,比如:Oracle、DB2、MSSQL。MySql虽然是免费的,但是处理大型数据还是要提前作很多工作的。
- 功能:实际开发中,很多业务需求,其实并不需要完整的关系型数据库功能,非关系型数据库的功能就足够使用了。这种情况下,使用性能更高、成本更低的非关系型数据库当然是更明智的选择。
概念性的区别如下表所示:
了解关系型数据库和非关系型数据库的区别后,需要有一点的取舍,比较复杂和大型的项目不建议使用非关系型数据库,但是如果你想作个博客,CMS系统这类业务逻辑不复杂的程序,MongoDB是完全可以胜任的。
mongoDB的操作语句:
查看数据库列表 $ Show dbs 检查数据库创建数据库 $ use 数据库名称创建集合 $ db.createCollection(“集合名”) // 集合 === 表>{ok:1}查看集合(一定先进入对应数据库再进行查看)$ db.getCollectionNames()>[‘集合名‘]插入数据 $ db.集合名.insertOne(数据集合({}json形式的数据)) // 文档 === 列>{"acknowledged" : true, //是否插入成功"insertedId" : ObjectId("5aab2aaa93468a71aec836ce”)//插入的id}查看数据 $ db.music.find() 查看数据库中的数据>{ "_id" : ObjectId("5aab2aaa93468a71aec836ce"), "title" : "回娘家" }{ "_id" : ObjectId("5aab2b5e93468a71aec836cf"), "title" : "再见理想" }Help命令db.help() //db下的指令db.test.help(); // db.test 下的所有指令db.test.find().help(); //db.test.find下的所有指令………强大的help指令使用数据库use 数据库名查询数据陆show dbs查看当前使用的数据库db/db.getName();显示当前的数据库状态db.stats();查看当前db的版本db.version();查看数据库连接地址;db.getMongo()删除数据库db.dropDatabase()tip:删除当前使用的数据库。集合(collection)操作1.创建createCollection(“collName”,{size:20,cappeu:true,max:10})2.得到指定名称的集合db.getCollection(“account”)3.得到当前db所有的集合;db.getCollectionNames()4.显示当前db所有集合状态db.printCollectionStats();5.删除集合db.COLLECTION_NAME.drop();集合数据操作(添加,修改,删除)update | updateMany()1.添加 insert([,…]|{key:value,...})db.users.save({name:”zhangsan”,”age”:25,sex:true})2.修改 updata(条件({}))db.users.update({age:25},{$set:{name:”changeName”}},false,true)相当于sql语句的 update users set name = “changeName” where age = 25;db.users.update({name:”Lisi”},{$inc:{age:50}},false,true)相当于sql语句的 update users set age = age + 50 where name =“lisi”db.users.update({name:”Lisi”},{$inc:{age:50},$set:{name:’hoho’}},false,true)相当于sql语句的 : update users set age = age + 50 ,name = ‘hoho’ where name = “lisi"3.删除db.users.remove({age:132})db.users.delete()db.users.deleteOne()db.users.deleteMany()豆瓣api api.douban.com/v12/movie/top369豆瓣数据的操作:获取到豆瓣的数据,然后将数据放入数据库之中。查找对应数据;db.movie.find(条件,显示内容)db.movie.find({year:1994},{title:1,year:1,_id:0})//表示显示 title1 和 year1 _id不显示;1.表示显示 0.表示不显示;排序根据评分排序:db.movie.find({},{title:1,year:1,_id:0,‘rating.average‘:1}).sort({‘rating.average‘:-1})条件判断:$gt 大于; $lt 小于; $gte 大于等于 $lte 小于等于;db.movie.find({‘arting.average’:$gt:9.5},{title:1,year:1,_id:0,‘rating.average‘:1}).sort({‘rating.average‘:-1})分类筛选:$in 包含 $nin 不包含db.movie.find({genres:{$in:["犯罪","剧情"]}},{title:1,year:1,_id:0,‘rating.average‘:1}).sort({‘rating.average‘:-1})