memcached     redis : kv数据库(key/value)

mongodb 文档数据库,存储的是文档(Bson->json对象二进制化后叫bson,js的二进制对象,引擎是用js实现的).

特点:内部执行引擎为JS解释器, 把文档存储成bson结构,在查询时,转换为JS对象,并可以通过熟悉的js语法来操作.

mongo和传统型数据库(mqsql)相比,最大的不同:
传统型数据库: 结构化数据, 定好了表结构后,每一行的内容,必是符合表结构的,就是说--列的个数,类型都一样.
mongo文档型数据库: 表下的每篇文档,都可以有自己独特的结构(json对象都可以有自己独特的属性和值) 思路: 如果有电影, 影评, 影评的回复, 回复的打分
在传统型数据库中, 至少要4张表, 关联度非常复杂.
在文档数据库中,通过1篇文档,即可完成. 体现出文档型数据库的反范式化.
{
fiim:’天龙八部’
comment:[
{content:’王家卫的电影风格’,
reply:[‘支持’,’好’]
}
]
}
mongodb的安装
1: 下载mongodb www.mongodb.org 下载最新的stable版
2: 解压文件
3: 不用编译,本身就是编译后的二进制可执行文件.

4: 启动mongod服务

5: mongodb非常的占磁盘空间, 刚启动后要占3-4G左右,
如果你用虚拟机练习,可能空间不够,导致无法启动.
可以用 --smallfiles 选项来启动,
将会占用较小空间 400M左右.

mongo也可以去连接其他数据库。

1.1: show dbs  查看当前的数据库,admin放的是和管理相关的,用户的操作,安全配置。Local:放其他数据库的信息,这2个库不要动。
1.2 use test 选库
1.2 show tables/collections 查看当前库下的collection,mongodb的表不叫表叫collection,
1.3 如何创建库?(没有createdatabase 命令)
Mongodb的库是隐式创建,你可以use 一个不存在的库,use shop就创建了一个库,
然后在该库下创建collection,即可创建库db.createCollection(‘user’)
创建collection,这样就创建了一个库和collection(表),把表创建完了库才能创建好。
use shop
db.createCollection("user")
show dbs:
admin 0.000GB
local 0.000GB
shop 0.000GB
test 0.000GB
表就是一个个的集合,里面是一个个的文档,没有表的结构。表里面就是一个个的json对象。
use shop
show tables
db.user.insert({name:"1yw",age:1120})
db.user.insert({name:"1yww",age:1120,tt:"1oo"})
db.user.insert({na:113,ageeee:"1888"})
db.user.insert({ _id : 1112, ma : 113, ageeee : "1888",aaa:{aa:"ll0",sss:"ddddd"} })
db.user.insert({_id:1113,ss:[123,"ddd",'kk'],ma: 113, ageeee : "1888",aaa:{aa:"ll0",sss:"ddddd"} }) db.user.find():
{ "_id" : ObjectId("5a448f0283c2d5efb2d581d8"), "name" : "yw", "age" : 120 }
{ "_id" : ObjectId("5a448f0283c2d5efb2d581d9"), "name" : "yww", "age" : 120, "tt
" : "oo" }
{ "_id" : ObjectId("5a448f0283c2d5efb2d581da"), "na" : 13, "ageeee" : "888" }
{ "_id" : ObjectId("5a448f8283c2d5efb2d581db"), "name" : "1yw", "age" : 1120 }
{ "_id" : ObjectId("5a448f8283c2d5efb2d581dc"), "name" : "1yww", "age" : 1120, "
tt" : "1oo" }
{ "_id" : ObjectId("5a448f8283c2d5efb2d581dd"), "na" : 113, "ageeee" : "1888" }
自己指定id:
{ "_id" : 1000, "name" : "1yw", "age" : 1120 }
{ "_id" : 1001, "name" : "1yww", "age" : 1120, "tt" : "1oo" }
{ "_id" : 1002, "na" : 113, "ageeee" : "1888" }
{ "_id" : 1113, "ss" : [ 123, "ddd", "kk" ], "ma" : 113, "ageeee" : "1888", "aaa
" : { "aa" : "ll0", "sss" : "ddddd" } } Collection的意思没有,表是有结构的是有意思的,collection只是一个口袋一个集合。
1.5 collection允许隐式创建
Db.collectionName.insert(document); show collections :user
db.goods.insert({1:1,2:'','':3}) //就默认创建了goods这个collectio(表),没必要提前创建,collectios是表的集合
show collections:goods user
db.goods.find()://不同的数据库不能操作,要切换数据库,
{ "_id" : ObjectId("5a44961e83c2d5efb2d581de"), "1" : 1, "2" : "2", "3" : 3 } 1.6 db.collectionName.drop() ,
删除collection
use test
show tables
db.user.drop()
show collections 1.7 db.dropDatabase();
删除database
use shop //先移到本数据库
show tables
db.dropDatabase() use test
show tables
db.dropDatabase()
show dbs

mongodb02的更多相关文章

  1. MONGODB02 - MongoSocketWriteException 异常会迟到,但从不缺席

    接上一个<MONGODB01 - Prematurely reached end of stream 错误定位及修复>处理完成之后,又报错了,场景也是一段时间不访问MongoDB,突然访问 ...

  2. 使用Scala操作Mongodb

    介绍 Scala是一种功能性面向对象语言.它融汇了很多前所未有的特性.而同一时候又执行于JVM之上.随着开发人员对Scala的兴趣日增,以及越来越多的工具支持,无疑Scala语言将成为你手上一件不可缺 ...

  3. mongDB主从

    MongoDB[第二篇]MongodDB主从 官方网站:http://www.mongodb.org/ MongoDB的一些参数 --logpath 日志文件路径 --master 指定为主机器 -- ...

  4. MongoDB用户权限认证

    关于用户的认证及权限 用户是跟着库创建的,在哪个库创建的什么权限的什么用户,只对此库有相应权限(除超级管理员以外). 官网文档:https://docs.mongodb.com/master/refe ...

  5. mongodb副本集原理及部署记录

    工作原理 1.副本集之间的复制是通过oplog日志现实的.备份节点通过查询这个集合就可以知道需要进行复制的操作 2.oplog是节点中local库中的一个固定的集合,在默认情况下oplog初始化大小为 ...

  6. mongodb拆库分表脚本

    脚本功能: 1. 将指定的报告文件按照指定的字段.切库切表策略切分 2. 将切分后的文件并发导入到对应的Mongodb中 3. 生成日志文件和done标识文件 使用手册: -h    打印帮助信息,并 ...

  7. Configure MongoDB Replica Set

    Table of Contents Introduction Requirements Create Replica Set Add Secondary Members Add an Arbiter ...

  8. 012.MongoDB读写分离

    一 读写分离概述 1.1 读写分离描述 从应用程序角度来看,使用Replica Set 和使用单台mongo很像.默认的驱动程序会连接primary节点,并且将所有读写请求都路由到主节点.但也可以通过 ...

  9. 011.MongoDB性能监控

    一 MongoDB 监控 1.1 监控概述 MongoDB自带了mongostat 和 mongotop 这两个命令来监控MongoDB的运行情况.这两个命令用于处理MongoDB数据库变慢等等问题非 ...

随机推荐

  1. luogu3415 祭坛

    先二分答案转化成判定问题. 考虑拿一根扫描线从 \(x=0\) 扫到 \(x=n\),每次移动扫描线更新每个位置它上面的点数和下面的点数,这样可以确定在当前的扫描线上哪些位置对于 \(y\) 轴方向是 ...

  2. 什么是slug URL 中的 slug

    How would you reference this object with a URL, with a meaningful name? You could use Article.id so ...

  3. python的unittest单元测试框架断言整理汇总

    自动化脚本最重要的是断言,正确设置断言以后才能帮助我们判断测试用例执行结果. 一.先说说unittest常用的断言吧 常用的就以下几个,网上一搜一大堆.python版本2.7以上都可以调用了. 断言语 ...

  4. uva12558 Egyptian Fractions (HARD version)(迭代深搜)

    Egyptian Fractions (HARD version) 题解:迭代深搜模板题,因为最小个数,以此为乐观估价函数来迭代深搜,就可以了. #include<cstdio> #inc ...

  5. windows7 下安装使用Redis

    Redis 安装使用 本地环境:Windows7 64位web环境:wamp集成环境,php版本:PHP Version 7.1.17 学习参考网站: RUNOOB.COM官网  http://www ...

  6. Flex 4 自定义预加载器

    本示例的目的是在Flash Professional里创建自定义预加载器SWC,并扩展SparkDownloadProgressBar类在Flex 4应用程序中使用.    预加载器显示加载进度百分比 ...

  7. eclipse提速01 - 禁用不常用的eclipse启动插件

    会不断更新,需要的收藏 禁用不常用的eclipse启动插件(当然如果不需要可以卸载)

  8. Meteor check

    check方法用于检查参数或类型是否匹配模式. 安装check包 打开命令提示符窗口,并安装该软件包. C:\Users\Administrator\Desktop\meteorApp>mete ...

  9. 【LeetCode】Swap Nodes in Pairs 链表指针的应用

    题目:swap nodes in pairs <span style="font-size:18px;">/** * LeetCode Swap Nodes in Pa ...

  10. coco2d-x怎样创建project

    不知道coco2d-x从那个版本号開始用python创建project,一句话搞定,确实省去了好多麻烦. 首先定位到coco2d-x的文件夹到cocos2d-x-2.2.3\cocos2d-x-2.2 ...