mongodb32位安装版 http://pan.baidu.com/s/1mhQVHl2
MongoDB64位绿色版 http://pan.baidu.com/s/1cMM9oq
mongo客户端 http://pan.baidu.com/s/1kUIQlUZ
先安装homebrew
http://brew.sh/
使用brew安装mongodb
brew install mongodb
再安装可视化工具 Robomongo
C:\Program Files\MongoDB 2.6 Standard\bin
D:\Mongodb\data
mongod --dbpath=刚创建的空目录
,如mongod --dbpath=D:\Mongodb\data
再按回车键
如果出现waiting for connections on port 27017
就表示启动成功,已经在27017端口上监听了客户端的请求
注意:--dbpath
后的值表示数据库文件的存储路径,而且后面的路径必须事先创建好,必须已经存在,否则服务开启失败
注意:这个命令窗体绝对不能关,关闭这个窗口就相当于停止了mongodb
服务
C:\Program Files\MongoDB 2.6 Standard\bin
按下Shift+鼠标右键,选择在此处打开命令窗口
命令窗体中输入 mongo --host=127.0.0.1 或者 mongo 按回车键
备注:--host后的值表示服务器的ip地址 备注: --host=127.0.0.1 表示的就是本地服务器,每次数据库都会默认连接test数据库
语法
use database_name database_name代表数据库的名字
注:如果此数据库存在,则切换到此数据库下,如果此数据库还不存在也可以切过来
实例
切换到 person
数据库下
语法
show dbs
备注: 我们刚创建的数据库person 如果不在列表内, 要显示它,我们需要向 person 数据库插入一些数据 db.person.insert({name:"zhangSan",age:30})
语法
db 或 db.getName()
注:db代表的是当前数据库 也就是person这个数据库
实例
语法
db.dropDatabase()
实例
语法
db.worker.help()
实例
语法
show collections
实例
创建一个空集合
db.createCollection(collection_Name) collection_Name集合的名称
创建集合并插入一个文档
db.collection_Name.insert(document)
语法
db.collection_name.insert(document)
`
参数
实例
每当插入一条新文档的时候mongodb会自动为此文档生成一个
_id
属性,_id一定是唯一的,用来唯一标识一个文档 _id也可以直接指定,但如果数据库中此集合下已经有此_id的话插入会失败
语法
db.collection_name.save(document)
参数
注:如果不指定 _id 字段 save() 方法类似于 insert() 方法。如果指定 _id 字段,则会更新该 _id 的数据。
实例
db.person.save({name:"xiaoHong",age:50})
db.person.save({_id:ObjectId("562c9caf671c978b6596e825"),name:"xiaoHong",age:10})
语法
db.collection.update(
<query>,
<updateObj>,
{
upsert: <boolean>,
multi: <boolean>
}
)
参数说明
实例 将document数据中name是liSi 的数据的name修改为liSi_update
db.worker.update({name:'liSi'},{$set:{name:'liSi_update'}})
注:如果有多条name是liSi的数据只更新一条,如果想全部更新需要指定{multi:true}的参数
remove方法是用来移除集合中的数据
语法
db.collection.remove(
<query>,
{
justOne: <boolean>
}
)
参数说明
实例 删除worker集合里name是fJianZhou的所有Document数据
db.worker.remove({name:'fJianZhou'})
删除person集合里name是xiaoHong的第一条数据
db.person.remove({name:"xiaoHong"},1)
语法
db.collection_name.find()
参数
实例 查询worker下所有的文档
db.worker.find()
语法
db.collection_name.find({queryWhere},{key:1,key:1})
参数列表
实例
db.worker.find({},{age:1}) 查询指定列
查询匹配结果的第一条数据 语法
db.collection_name.findOne()
实例
db.worker.findOne()
条件操作符用于比较两个表达式并从mongoDB集合中获取数据
语法
db.collectoin_name.find({<key>:{$gt:<value>}})
参数
实例
db.worker.find({age:{$gt:30}}) 查询age 大于 30的数据
语法
db.collectoin_name.find({<key>:{$gte:<value>}})
参数
实例
db.worker.find({age: {$gte: 30}}) 查询age 3大于等于30 的数据
语法
db.collectoin_name.find( {<key>:{$lt:<value>}})
参数
实例
db.worker.find({age: {$lt: 30}}) 查询age 小于30的数据
语法
db.collectoin_name.find({<key>:{$lte:<value>}})
参数
实例
db.worker.find({age: {$lte: 30}}) 查询age 小于等于30的数据
语法
db.collectoin_name.find({<key>:{$gte:<value>},<key>:{$lte:<value>}})
参数
实例 查询age 大于等于 30 并且 age 小于等于 50 的数据
db.worker.find({age: {$gte: 30, $lte: 50}})
语法
db.collectoin_name.find({<key>:<value>,<key>:<value>})
参数
实例 查询age = 30的数据
db.worker.find({"age": 30})`
语法
db.collectoin_name.find({"_id" : ObjectId("value")})
参数
_id
的值实例 查询_id是 562af23062d5a57609133974 数据
db.worker.find({"_id" : ObjectId("562af23062d5a57609133974")})
语法
db.collectoin_name.find().count()
参数
实例
db.worker.find().count()
语法
db.collection.find({key:/value/})
参数
实例 查询name里包含zhang的数据
db.worker.find({name:/value/})
查询某个字段的值当中是否以另一个值开头
db.worker.find({name:/^zhang/})
find方法可以传入多个键(key),每个键(key)以逗号隔开
语法
db.collection_name.find({key1:value1, key2:value2})
实例 查询name是zhangRenYang并且age是30的数据
db.worker.find({name:'zhangRenYang',age:30})
语法
db.collection_name.find(
{
$or: [
{key1: value1}, {key2:value2}
]
}
)
实例 查询age = 30 或者 age = 50 的数据
db.worker.find({$or:[{age = 30},{age = 50}]})
语法
db.collection_name.find(
{
key1:value1,
key2:value2,
$or: [
{key1: value1},
{key2:value2}
]
}
)
实例 查询 name是zhangRenYang 并且 age是30 或者 age是 50 的数据
db.worker.find({name:'zhangRenYang',$or:[{age:30},{age:50}]})
读取指定数量的数据记录 语法
db.collectoin_name.find().limit(number)
参数
实例 查询前3条数据
db.worker.find().limit(3)
跳过指定数量的数据,skip方法同样接受一个数字参数作为跳过的记录条数 语法
db.collectoin_name.find().skip(number)
参数
实例 查询3条以后的数据
db.worker.find().skip(3)
通常用这种方式来实现分页功能 语法
db.collectoin_name.find().skip(skipNum).limit(limitNum)
参数
实例 查询在4-6之间的数据
db.worker.find().sort({age:-1})
sort()方法可以通过参数指定排序的字段,并使用 1 和 -1 来指定排序的方式,其中 1 为升序排列,而-1是用于降序排列。 语法
db.collectoin_name.find().sort({key:1})
db.collectoin_name.find().sort({key:-1})
参数
实例 查询出并升序排序 {age:1} age表示按那个字段排序 1表示升序
db.worker.find().sort({age:1})