mongodb想速成吗,这个系列教程你能够看看(2)mongodb
MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。shell
在高负载的状况下,添加更多的节点,能够保证服务器性能。数据库
MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。json
MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档相似于 JSON 对象。字段值能够包含其余文档,数组及文档数组windows
www.mongodb.com/download-ce… 选择适合本身的版本。 数组
网站数据、缓存等大尺寸、低价值的数据缓存
在高伸缩性的场景,用于对象及JSON数据的存储。bash
数据库服务器
MongoDB的一个实例能够拥有一个或多个相互独立的数据库,每一个数据库都有本身的集合。数据结构
集合
集合能够看做是拥有动态模式的表。
文档
文档是MongoDB中基本的数据单元,相似于RDB的行。文档是键值对的一个有序集合。在JS中,文档被表示成对象。
_id
每一个文档都有个特殊的“_id”,在文档所属集合中是惟一的。
JavaScript shell
MongoDB自带了一个功能强大的JavaScript Shell,能够用于管理或操做MongoDB
举例
添加服务 在命令行工具里
mongod.exe --dbpath E:\mongodata --logpath E:\mongolog --logappend --directoryperdb --serviceName mongodb --install
复制代码
启动mongodb服务
mongod --dbpath=E:\Mongodb\data
复制代码
若是出现waiting for connections on port 27017就表示启动成功,已经在27017端口上监听了客户端的请求注:启动说明
选项 | 含义 |
---|---|
--port | 指定服务端口号,默认端口27017 |
--logpath | 指定MongoDB日志文件,注意是指定文件不是目录 |
--logappend | 使用追加的方式写日志 |
--dbpath | 指定数据库路径 |
--directoryperdb | 设置每一个数据库将被保存在一个单独的目录 |
接着,再打开一个新的命令行窗口,输入
mongo
复制代码
就能够连接到数据库了
最后介绍一款mongodb可视化工具 Studio3T
use database_name
// 例如咱们这里能够建一个叫school的数据库
use school
复制代码
database_name 表明数据库的名字
注:若是此数据库存在,则切换到此数据库下,若是此数据库还不存在也能够切过来,可是并不能马上建立数据库 切换到 school数据库下
show dbs
复制代码
备注: 咱们刚建立的数据库school若是不在列表内, 要显示它,咱们须要向school数据库插入一些数据 db.students.insert({age:1});
inert数据以后
db
复制代码
注:db表明的是当前数据库 也就是school这个数据库
db.dropDatabase()
复制代码
school数据库就没了
use demo
db.demo.help()
复制代码
db.createCollection(collection_Name)
复制代码
collection_Name集合的名称
collection_Name集合的名称 document要插入的文档
db.collection_Name.insert(document)
// 例如
db.demo.insert({age:1})
复制代码
以前咱们使用MySQL等关系型数据库时,主键都是设置成自增的。但在分布式环境下,这种方法就不可行了,会产生冲突。为此,MongoDB采用了一个称之为ObjectId的类型来作主键。ObjectId是一个12字节的 BSON 类型字符串。按照字节顺序,一次表明:
- | - |
---|---|
4字节: | UNIX时间戳 |
3字节: | 表示运行MongoDB的机器 |
2字节: | 表示生成此_id的进程 |
3字节: | 由一个随机数开始的计数器生成的值 |
show collections
复制代码
db.getName() 或者 db
复制代码
db.dropDatabase()
复制代码
db.collection_name.insert(document);
复制代码
collection_name 集合的名字
document 插入的文档
注:每当插入一条新文档的时候mongodb会自动为此文档生成一个_id属性,_id必定是惟一的,用来惟一标识一个文档 _id也能够直接指定,但若是数据库中此集合下已经有此_id的话插入会失败
db.demo.insert({_id:1,age:1});
复制代码
db.collection_name.save(document)
复制代码
collection_name 集合的名字 document 插入的文档
注:若是不指定 _id 字段 save() 方法相似于 insert() 方法。若是指定 _id 字段,则会更新该 _id 的数据。 咱们save以前保存过的id=1的数据,看是否是更新了此条数据
db.demo.save({_id:1, age:2})
复制代码
db.collection.update(
<query>,
<updateObj>,
{
upsert: <boolean>,
multi: <boolean>
}
)
复制代码
参数 | - |
---|---|
query | 查询条件,指定要更新符合哪些条件的文档 |
update | 更新后的对象或指定一些更新的操做符 |
$set | 在原基础上累加 |
upsert | 可选,这个参数的意思是,若是不存在符合条件的记录时是否插入updateObj. 默认是false,不插入。 |
multi | 可选,mongodb 默认只更新找到的第一条记录,若是这个参数为true,就更新全部符合条件的记录。 |
db.demo.insert({name: 'zhangsan'});
db.demo.update({name:'zhangsan'},{age:12})
复制代码
将students集合中数据中name是lisi的值修改成lisi,由于原表根本不存在name:lisi的,本来不会插入这一条数据,可是upsert选项设为了true就插入成功了
db.demo.update({name:'lisi'}, {name:'lisi'}, {upsert:true});
复制代码
若是有多条age是1的数据只更新一条,若是想所有更新须要指定{multi:true}的参数
db.school.insert({age:1});
db.school.insert({age:1});
db.school.insert({age:1});
db.school.update({age:1}, {$set:{name:'lisi'}}, {multi:true});
db.school.find({})
复制代码
直接指定更新后的值
use c3;
db.c3.insert({name:'a'});
db.c3.update({name:'a'},{$set:{age:10}});
db.c3.find({})
复制代码
在原基础上累加
db.c3.update({name:'a'},{$inc:{age:1}});
复制代码
删除指定的键
db.c3.update({name:'2'},{$unset:{age:11}});
复制代码
向数组中添加元素
var result = db.student.update({name:'张三'},{
$push:{"hobbys":"smoking"}
});
复制代码
$ne相似于MYSQL的 not in 或者not exists
db.c3.update({hobbys:{$ne:"eating"}},{$push:{"hobbys":"sleeping"}});
复制代码
向集合中添加元素
db.c3.update({a:1},{$addToSet:{"hobbys":"smoking"}});
复制代码
把数组中的元素逐个添加到集合中
db.a.insert({name:'a', hobbys:[1,2]});
db.a.update({name:'a'},{$addToSet:{hobbys:{$each:[3,4]}}});
db.a.find()
复制代码
从数组中移除指定的索引中对应的元素
db.c3.update({name:'a'},{$pop:{hobbys:1}});
db.c3.find()
复制代码
db.c3.update({name:'zfpx1'},{$set:{"hobbys.0":"smoking2"}});
复制代码
remove方法是用来移除集合中的数据
db.collection.remove(
<query>,
{
justOne: <boolean>
}
)
复制代码
- | - |
---|---|
query | (可选)删除的文档的条件。 |
justOne | (可选)若是设为 true 或 1,则只删除匹配到的多个文档中的第一个 |
删除worker集合里name是zfpx2的全部文档数据
db.c3.remove({name:'a'});
复制代码
db.c3.remove({name:'a'},{justOne:true});
复制代码
语法
db.collection_name.find()
复制代码
参数
- | - |
---|---|
collection_name | 集合的名字 |
实例
查询c3下全部的文档
db.students.find()
复制代码
语法
db.collection_name.find({queryWhere},{key:1,key:1})
复制代码
参数列表
- | - |
---|---|
collection_name | 集合的名字 |
queryWhere | 参阅查询条件操做符 |
key | 指定要返回的列 |
1 | 表示要显示 |
实例
只返回显示age列
db.c3.insert([{name:1,age:2},{name:1,age:3},{name:1,age:4}]);
db.c3.find({},{_id:0, age:1});
复制代码
查询匹配结果的第一条数据 语法
db.collection_name.findOne()
复制代码
实例
db.c3.findOne()`
复制代码
查询字段在某个范围内
db.c3.insert([{age:30, name:1},{age:100, name:2},{age:40, name:3},{age:60, name:4}])
db.c3.find({age:{$in:[30,100]}},{name:1,age:1});
复制代码
查询字段不在某个范围内
db.c3.find({age:{$nin:[30,100]}},{name:1,age:1});
复制代码
对特定条件取反
db.c3.find({age:{$not:{$gte:20,$lte:30}}});
复制代码
对数组的查询
// 按全部元素匹配
db.c3.find({friends:[ "A", "B", "C", "D" ]});
//匹配一项 包含A的就能够
db.c3.find({friends:"A"});
// $all 必须同时包含A B
db.c3.find({friends:{$all:['A',"B"]}});
// $in 或者关系 ,包含A或者B
db.c3.find({friends:{$in:['A',"B"]}});
//$size 按数组的长度去匹配
db.c3.find({friends:{$size:4}});
//$slice 只返回数组中的某一部分
db.c3.find({friends:{$size:5}},{name:1,friends:{$slice:2}});
db.c3.find({friends:{$size:5}},{name:1,friends:{$slice:-2}});
$slice:["$array", [startIndex, ] length ] (startIndex能够省略,默认从0开始)
db.c3.find({},{friends:{$slice:[0,3]}});
复制代码
db.c3.find({$where:"this.age>30"},{name:1,age:1});
复制代码
游标不是查询结果,而是查询的一个返回资源或者接口,经过这个接口,能够逐条读取数据
var result = db.student.find();
while(result.hasNext()){
printjson(result.next());
}
复制代码
条件操做符用于比较两个表达式并从mongoDB集合中获取数据
参数
- | - |
---|---|
$gt | 大于 |
$gte | 大于等于 |
$lt | 小于 |
$lte | 小于等于 |
语法
db.collectoin_name.find({"_id" : ObjectId("value")})
复制代码
查询_id是 562af23062d5a57609133974 数据
db.stuc3dents.find({_id:ObjectId("5adb666ecd738e9771638985")});
复制代码
语法
db.collectoin_name.find().count();
复制代码
db.c3.find().count()
复制代码
语法
db.collection.find({key:/value/})
复制代码
参数
- | - |
---|---|
collectoin_name | 集合名称 |
key | 字段 |
value | 值 |
查询name里包含joe的数据,正则只能匹配字符串
db.user.find({name:/joe/})
复制代码
find方法能够传入多个键(key),每一个键(key)以逗号隔开
语法
db.collection_name.find({key1:value1, key2:value2})
复制代码
查询name是1而且age是30的数据
db.students.find({name:1,age:30})
复制代码
语法
db.collection_name.find(
{
$or: [
{key1: value1}, {key2:value2}
]
}
)
复制代码
查询age = 30 或者 age = 100 的数据
db.c3.find({$or:[{age:30},{age:100}]})
复制代码
语法
db.collection_name.find(
{
key1:value1,
key2:value2,
$or: [
{key1: value1},
{key2:value2}
]
}
)
复制代码
实例 查询 age是30 而且 name是1或者 name是 3 的数据
db.c3.find({age: 30, $or:[{name:1},{age:3}]})
复制代码
读取指定数量的数据记录 语法
db.collectoin_name.find().limit(number)
复制代码
var a = [];
for(var i = 0;i<10;i++){
a.push({age:i})
};
db.c3.insert(a);
db.students.find().limit(3)
复制代码
跳过指定数量的数据,skip方法一样接受一个数字参数做为跳过的记录条数 语法
db.collectoin_name.find().skip(number)
复制代码
db.c3.find().skip(3)
复制代码
一般用这种方式来实现分页功能 语法
db.collectoin_name.find().skip(skipNum).limit(limitNum)
复制代码
db.c3.find().skip(3).limit(3);
复制代码
sort()方法能够经过参数指定排序的字段,并使用 1 和 -1 来指定排序的方式,其中 1 为升序排列,而-1是用于降序排列。 语法
db.collectoin_name.find().sort({key:1})
db.collectoin_name.find().sort({key:-1})
复制代码
db.c3
.find().sort({age:1})
复制代码