首先安装mongodb
1.下载地址:
2.解压缩到自己想要安装的目录,比如F:\mongodb
4.运行cmd进入dos命令界面,执行下列命令
> cd F:\mongodb\bin
> F:\mongodb\bin>mongod -dbpath "F:\mongodb\db"默认MongoDB监听的端口是270175.新开一个cmd窗口,进入mongodb的bin目录,输入mongo或者mongo.exe,如果测试通过,那么我们就已经进入了test这个数据库。输入exit或者ctrl+C可退出。
6.当mongod.exe被关闭时,mongo.exe 就无法连接到数据库了,因此每次想使用mongodb数据库都要开启mongod.exe程序,所以比较麻烦,此时我们可以将MongoDB安装为windows服务
还是运行cmd,进入bin文件夹,执行下列命令:
> F:\mongodb\bin>mongod –dbpath "F:\mongodb\db" –logpath "F:\mongodb\log\MongoDB.log" –install –serviceName "MongoDB"
这里MongoDB.log就是开始建立的日志文件,–serviceName "MongoDB" 服务名为MongoDB
接着启动mongodb服务
打开任务管理器,可以看到进程已经启动
7.关闭服务和删除进程
> F:\mongodb\bin>NETstop MongoDB (关闭服务)
> F:\mongodb\bin>mongod –dbpath "F:\mongodb\db" –logpath "F:\mongodb\log\MongoDB.log" –remove –serviceName "MongoDB" (删除,注意不是–install了)8.如果不想每次运行时切换目录,可以将MongoDB的安装路径添加到path中,如案例中的:F:\mongodb\bin
–创建库
use navy
–显示库
show db; show dbs
–创建集合
db.createCollection("mycollection",{"autoIndexID":true}); –可通过db.help()查询具体的使用方式
–显示集合
show collections
–删除集合
db.collection_name.drop();
–添加数据
db.mycollection.insert([{"name":"yc","addr":"湖南益阳"},{"name":"navy","addr":"湖南衡阳"}])
db.mycollection.insert({"_id":1,"company":"yc","url":"","pageViews":1})
db.mycollection.insert({"_id":2,"company":"ycs","url":"","pageViews":1})
–save()方法 如果集合中存在,则替换,否则添加
db.mycollection.save({"_id":1,"company":"ycInfo","url":"","pageViews":1}) –替换
db.mycollection.save({"_id":3,"company":"yc","url":"","pageViews":1}) –添加
–修改
update() 方法的基本语法如下:
db.COLLECTION_NAME.update(SELECTIOIN_CRITERIA, UPDATED_DATA)
–$inc修改器 将pageViews的值增加1
db.mycollection.update({"_id":1},{"$inc":{"pageViews":1}})
–$set
db.mycollection.update({"_id":2},{"$set":{"pageViews":100,"company":"navy"}})
–将公司改成一个数组
db.mycollection.update({"_id":2},{"$set":{"company":["navy","yc","hg"]}})
–删除company健
db.mycollection.update({"_id":2},{"$unset":{"company":1}})
–数组修改器
–$push添加元素
db.mycollection.update({"_id":2},{"$push":{"company":"sc"}})
–$each添加多个
db.mycollection.update({"_id":2},{"$push":{"company":{"$each":["rc","zr"]}}})
–$slice 要来保证数组的长度
db.mycollection.update({"_id":2},{"$push":{"company":{"$each":["rc","zr","navy","yc","hg"],"$slice":-10}}}) –只保留最后的10个数,$slice的值必须为负
–$ne/$addToSet主要给数组类型键值添加一个元素时,避免在数组中产生重复数据,$ne在有些情况是不通行的。
db.mycollection.update({"_id":2},{$addToSet:{"company":"yc"}}) –不成功
db.mycollection.update({"_id":2},{$addToSet:{"company":"yc1"}}) –成功
–$pop从数组中删除元素{$pop:{"<key>":1}}从数组末尾删除一个元素。{$pop:{"<key>":-1}}从头部删除一个元素
db.mycollection.update({"_id":2},{$pop:{"company":1}})
–$pull从数组中删除所有匹配的元素
db.mycollection.update({"_id":2},{$pull:{"company":"zr"}})
–$基于位置的数组修改器
若是数组有多个值,而我们只想对其中的一部分进行修改,,可以通过位置或者定位操作符"$"
数组下表是从0开始的,可以将下标直接作为键来选择元素。例如:
db.blog.insert({
"_id":1001,
"content":"源辰信息科技有限公司",
"comments":[{
"comment":"很好的公司",
"author":"大军",
"votes":100
},{
"comment":"学习的乐园",
"author":"小军",
"votes":1001
},
{
"comment":"快乐地成长之地",
"author":"小小军",
"votes":100
}]
})
如果想要增加第一个评论的投票数,可以这么做;
db.blog.update({"_id":1001},{$inc:{"comments.0.votes":1}})
但很多情况下,不预先查询文档就不能知道要修改的数组的小标。为了克服这个困难,MongoDB提供了定位操作符$,用来定位查询文档已经匹配的数组元素,并进行更新。
db.blog.update({"comments.author":"小军"},{$set:{"comments.$.author":"小军哥"}});
MongoDB默认将只更新单一的文件,更新多个你需要设置参数置’multi’ 为true
db.blog.update({‘title’:’MongoDB Overview’},{$set:{‘title’:’New MongoDB Tutorial’}},{multi:true})
db.blog.update({‘title’:’MongoDB Overview’},{$set:{‘title’:’New MongoDB Tutorial’}},false,true);
–条件查询
db.mycollection.find()
db.mycollection.findOne().pretty(); –pretty()格式化输出
db.mycollection.find({"<key>":"<val>"}) –where <key> = <val>
db.mycollection.find({"<key>":{$lt:<val>}}) –where <key> < <val>
db.mycollection.find({"<key>":{$lte:<val>}}) –where <key> <= <val>
db.mycollection.find({"<key>":{$gt:<val>}}) –where <key> > <val>
db.mycollection.find({"<key>":{$gte:<val>}}) –where <key> >= <val>
db.mycollection.find({"<key>":{$ne:<val>}}) –where <key> != <val>
–in
db.mycollection.find({"<key>":{$in:[<val>]}})
–and
db.mycollection.find({"name":"navy","addr":"湖南衡阳"}).pretty() –where <key> != <val>
–or
db.mycollection.find({$or:[{"name":"navy"},{"addr":"湖南衡阳"}]}).pretty()
–and and or
db.mycollection.find({"name":"yc",$or:[{"name":"navy"},{"addr":"湖南衡阳"}]}).pretty()
游标操作
for(i=0;i<100;i++){
db.collection.insert({x:i});
}
var cursor=db.collection.find();
var obj;
while(cursor.hasNext()){
obj=cursor.next();
display(obj);
}
游标还实现了JavaScript的迭代接口,所以可以在forEach循环中使用
cursor.forEach(function(x){
print(x)
});
db.collection.find().limit(3) –返回前三个
db.collection.find().skip(3); –略过前三个
sort接受一个对象作为参数,这个对象是一组键/值对,键对应文档的键名,值为排序规则。1为升序,-1为降序。
db.collection.sort({username:1,age:-1});
分页每页10条
第一页:db.collection.find({"desc":"mp3"}).limit(10).sort({"price":-1});
下一页:db.collection.find({"desc":"mp3"}).skip(10).limit(10).sort({"price":-1});
索引:
db.collection.ensureIndex({"age":1,"username":1}) –在age和username上建立符合索引
版权声明:本文为博主原创文章,未经博主允许不得转载。
当你困难失望的时候,最重要的是事瞧得起你自己;