启动方法还是在命令行里输入命令:
`mongod --dbpath=D:\Projects\mongodb\db`
```
D:\Projects\mongodb\bin>mongod --dbpath=D:\Projects\mongodb\db
```
<!--more-->
发现打不开,原因:
```
2015-06-29T10:13:01.490+0800 W - [initandlisten] Detected unclean shutdown - D:\Projects\mongodb\db\mongod.lock is not empty.
```
先删掉`D:\Projects\mongodb\db\mongod.lock`即可。重新输入命令打开。
发现正常:
```
2015-06-29T10:13:31.181+0800 I CONTROL [initandlisten] options: { storage: { dbPath: "D:\Projects\mongodb\db" } }
2015-06-29T10:13:31.994+0800 I NETWORK [initandlisten] waiting for connections on port 27017
2015-06-29T10:13:52.033+0800 I NETWORK [initandlisten] connection accepted from 127.0.0.1:52691 #1 (1 connection now open)
```
再打开一个新的命令行窗口,输入mongo即可:
`D:\Projects\mongodb\bin>mongo`
默认打开`test`数据。
先看看昨天存的数据还在不在,集合名词是person:
```
> db.person.find()
{ "_id" : ObjectId("558fd39d02d9b5bcf004aaf5"), "name" : "yjc", "age" : 22 }
```
数据依然存在。
## Insert操作
上一篇也说过,文档是采用“K-V”格式存储的,如果大家对JSON比较熟悉的话,我相信学mongodb是手到擒来,我们知道JSON里面Value可能是“字符串”,可能是“数组”,又有可能是内嵌的一个JSON对象,相同的方式也适合于BSON。
常见的插入操作也就两种形式存在:“单条插入”和“批量插入”。
### 单条插入
先前也说了,mongo命令打开的是一个javascript shell。所以js的语法在这里面都行得通,看起来是不是很牛X。
```
> var data = {"name":"liyi", "age": 20, "address" : {"province" : "hubei", "city" : "wuhan"}, "favourite" : ["music", "movie"]};
> db.person.insert(data);
WriteResult({ "nInserted" : 1 })
```
新增成功。使用了js的语法。再来一条:
```
var stu = {};
stu.name = "lier";
stu.age = 10;
stu.adress = {"province" : "hubei", "city" : "yichang"};
db.person.insert(stu);
```
新增成功。
```
WriteResult({ "nInserted" : 1 })
> db.person.find();
{ "_id" : ObjectId("558fd39d02d9b5bcf004aaf5"), "name" : "yjc", "age" : 22 }
{ "_id" : ObjectId("5590ac85c8e4762462ebbab2"), "name" : "liyi", "age" : 20, "address" : { "province" : "hubei", "city" : "wuhan" }, "favourite" : [ "music", "movie" ] }
{ "_id" : ObjectId("5590adecc8e4762462ebbab3"), "name" : "lier", "age" : 10, "adress" : { "province" : "hubei", "city" : "yichang" } }
```
### 批量插入
这玩意跟“单条插入”的差异相信大家应该知道,由于mongodb中没有提供给shell的“批量插入方法”,没关系,各个语言的driver都打通了跟mongodb内部的批量插入方法,因为该方法是不可或缺的,如果大家非要模拟下批量插入的话,可以自己写了for循环,里面就是insert。
## Find操作
日常开发中,我们玩查询,玩的最多的也就是二类:
```
1) >, >=, <, <=, !=, =
2) And,OR,In,NotIn
```
这些操作在mongodb里面都封装好了,下面就一一介绍:
1) `"$gt", "$gte", "$lt", "$lte", "$ne", "没有特殊关键字"`,这些跟上面是一一对应的,举几个例子。
```
/*查找大于20岁的*/
> db.person.find({"age": {$gt: 20 }})
{ "_id" : ObjectId("558fd39d02d9b5bcf004aaf5"), "name" : "yjc", "age" : 22 }
/*查找小于20岁的*/
> db.person.find({"age": {$lt: 20 }})
{ "_id" : ObjectId("5590adecc8e4762462ebbab3"), "name" : "lier", "age" : 10, "adress" : { "province" : "hubei", "city" : "yichang" } }
/*查找等于20岁的*/
> db.person.find({"age": 20})
{ "_id" : ObjectId("5590ac85c8e4762462ebbab2"), "name" : "liyi", "age" : 20, "address" : { "province" : "hubei", "city" : "wuhan" }, "favourite" : [ "music", "movie" ] }
```
2) `"无关键字“, "$or", "$in","$nin"` 同样我也是举几个例子
```
/*查找age=18 && adress.city="wuhan"*/
> db.person.find({"age": {$gt: 18 },"address.city" : "wuhan"})
"_id" : ObjectId("5590ac85c8e4762462ebbab2"), "name" : "liyi", "age" : 20, "address" : { "province" : "hubei", "city" : "wuhan" }, "favourite" : [ "music", "movie" ] }
/*查找age=18 || age=22*/
> db.person.find({"age": {$in: [22 , 10]}});
{ "_id" : ObjectId("558fd39d02d9b5bcf004aaf5"), "name" : "yjc", "age" : 22 }
{ "_id" : ObjectId("5590adecc8e4762462ebbab3"), "name" : "lier", "age" : 10, "adress" : { "province" : "hubei", "city" : "yichang" } }
/*查找age=10 || name="yjc"*/
> db.person.find({$or: [{"age": 10}, {"name" : "yjc"}]});
{ "_id" : ObjectId("558fd39d02d9b5bcf004aaf5"), "name" : "yjc", "age" : 22 }
{ "_id" : ObjectId("5590adecc8e4762462ebbab3"), "name" : "lier", "age" : 10, "adress" : { "province" : "hubei", "city" : "yichang" } }
```
3) 在mongodb中还有一个特殊的匹配,那就是“正则表达式”,这玩意威力很强的。
```
/*查找name里含有字母c的*/
> db.person.find({"name" : /c+/});
{ "_id" : ObjectId("558fd39d02d9b5bcf004aaf5"), "name" : "yjc", "age" : 22 }
```
4) 有时查询很复杂,很蛋疼,不过没关系,mongodb给我们祭出了大招,它就是`$where`,为什么这么说,是因为`$where`中的value就是我们非常熟悉,非常热爱的js来助我们一马平川。
```
> db.person.find({$where : function(){return this.name == "yjc"}});
{ "_id" : ObjectId("558fd39d02d9b5bcf004aaf5"), "name" : "yjc", "age" : 22 }
```
## Update操作
更新操作无非也就两种,整体更新和局部更新,使用场合相信大家也清楚。记住第一个参数是条件。
### 整体更新
不知道大家可还记得,我在上一篇使用update的时候,其实那种update是属于整体更新。
```
db.person.find({"name" : "yjc"});
var where = {"name" : "yjc"};
var model = db.person.findOne(where);
model.age = 25; //重新赋值
model.address = {"city" : "beijing"};
db.person.update(where, model);
```
看运行结果:
```
> db.person.find({"name" : "yjc"});
{ "_id" : ObjectId("558fd39d02d9b5bcf004aaf5"), "name" : "yjc", "age" : 22 }
> var where = {"name" : "yjc"};
> var model = db.person.findOne(where);
> model.age = 25;
25
> model.address = {"city" : "beijing"};
{ "city" : "beijing" }
> db.person.update(where, model);
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.person.find({"name" : "yjc"});
{ "_id" : ObjectId("558fd39d02d9b5bcf004aaf5"), "name" : "yjc", "age" : 25, "address" : { "city" : "beijing" } }
```
说明:findOne与find的区别是,如果存在符合条件的记录,findOne只返回其中的第一条记录,而不是返回cursor。当不存在符合条件记录的时候,findOne返回null。是一种对find的补充。
### 局部更新
有时候我们仅仅需要更新一个字段,而不是整体更新,那么我们该如何做呢?easy的问题,mongodb中已经给我们提供了两个修改器: `$inc` 和 `$set`。
1) `$inc`修改器
` $inc`也就是increase的缩写,学过sql server 的同学应该很熟悉,比如我们做一个在线用户状态记录,每次修改会在原有的基础上自增$inc指定的值,如果“文档”中没有此key,则会创建key,下面的例子一看就懂。
```
> db.person.update({"name" : "yjc"}, {$inc : {"age" : 5}}); //age 增加5
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.person.find({"name" : "yjc"}); 5
{ "_id" : ObjectId("558fd39d02d9b5bcf004aaf5"), "name" : "yjc", "age" : 30, "address" : { "city" : "beijing" } }
```
2) `$set`修改器
与$inc用法格式一样,功能是设置为一个新值。
```
>db.person.update({"name" : "yjc"}, {$set : {"age" : 5}}); //age 设置为5
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.person.find({"name" : "yjc"}); 为5
{ "_id" : ObjectId("558fd39d02d9b5bcf004aaf5"), "name" : "yjc", "age" : 5, "address" : { "city" : "beijing" } }
```
### upsert操作
这个可是mongodb创造出来的“词”,大家还记得update方法的第一次参数是“查询条件”吗?
那么这个upsert操作就是说:如果我没有查到,我就在数据库里面新增一条,其实这样也有好处,就是避免了我在数据库里面判断是update还是add操作,使用起来很简单将update的第三个参数设为true即可。
```
db.person.update({"name" : "yjc2"}, {$set : {"age" : 25}}, true); //如果不存在则新增
```
### 批量更新
在mongodb中如果匹配多条,默认的情况下只更新第一条,那么如果我们有需求必须批量更新,那么在mongodb中实现也是很简单的,在update的第四个参数中设为true即可。例子就不举了。
## Remove操作
这个操作在上一篇简单的说过,这里就不赘述了。