MangoDB数据库概述

(一)什么是MangoDB数据库

            MongoDB是一个跨平台,面向文档的数据库,提供高性能,高可用性和易于扩展。MongoDB是工作在集合和文档上一种概念。是使用C++编写的

           面向集合, 意思是数据被分组到若干集合,这些集合称作聚集(collections). 在数据库里每个聚集有一个唯一的名字,可以包含无限个文档. 聚集是RDBMS中表的同义词,区别是聚集不需要进行模式定义.

            模式自由, 意思是数据库并不需要知道你将存入到聚集中的文档的任何结构信息.实际上,你可以在同一个聚集中存储不同结构的文档.

            文档型, 意思是我们存储的数据是键-值对的集合,键是字符串,值可以是数据类型集合里的任意类型,包括数组和文档. 我们把这个数据格式称作 “[BSON]” 即 “Binary Serialized dOcument Notation.”

集 文档数据库,键值对存储和关系型数据库的优点于一身.

(二)MangoDB的适用场景

             * 网站数据:Mongo非常适合实时的插入,更新与查询,并具备网站实时数据存储所需的复制及高度伸缩性。

            * 缓存:由于性能很高,Mongo也适合作为信息基础设施的缓存层。在系统重启之后,由Mongo搭建的持久化缓存层可以避免下层的数据源过载。

            * 大尺寸,低价值的数据:使用传统的关系型数据库存储一些数据时可能会比较昂贵,在此之前,很多时候程序员往往会选择传统的文件进行存储。

            * 高伸缩性的场景:Mongo非常适合由数十或数百台服务器组成的数据库。Mongo的路线图中已经包含对MapReduce引擎的内置支持。

            * 用于对象及JSON数据的存储:Mongo的BSON数据格式非常适合文档化格式的存储及查询。

(三)  Mangodb的缺陷

       1.存储的数据占用的空间过大

       2.不适用高度事务性的系统:例如银行或会计系统。传统的关系型数据库目前还是更适用于需要大量原子性复杂事务的应用程序。

       3.不适用传统的商业智能应用:针对特定问题的BI数据库会对产生高度优化的查询方式。对于此类应用,数据仓库可能是更合适的选择。

(四)MangoDB的操作指令

           1.命令行

                1)进入:mongo

                2)   退出:exit

           2.库级操作

                1)显示所有数据库:show dbs

                2)查看当前库:db    #默认进入test库

                3)切换/创建数据库:use 数据库名 # 不存在则创建

                4)删除数据库(删除当前库):db.dropDatabase()

                        *****数据库只有插入数据库才会真正的创建

          3.  集合操作

                1)显示当前数据库的所有集合:show collections

                2)创建集合:db.createCollection('name')

                3)删除集合:db.集合名字.drop()

                    ***创建集合后要插入一个文档(记录),集合才会真正的创建    

                     *****命令大小写敏感

            4.文档(数据)操作

                 1)添加文档:添加文档时,如果不指定_id参数,mongodb会为文档分配一个

                      *添加单条:db.集合名.insert({name:'xx',age:18})

                       *添加多条:db.集合名.insertMany([{name:'xx',age:18},{name:'xx',age:18}])

                2)查询:

                     *语法:db.collection_name.find(query, projection)

                      query :可选,使用查询操作符指定查询条件

                      projection :可选,使用投影操作符指定返回的键。查询时返回文档所有键值, 只需省略该参数即可(默认省略)。

                    *查看集合中的所有数据:db.collection_name.find()

                    *格式化输出:db.collection_name.find().pretty()

                    *查看满足条件的数据:db.collection_name.find({_id: 1})

                    *指定返回的键:db.collection_name.find(query, {name:1, age:1})

                    *指定不返回的键:db.collection_name.find(query, {name:0, age:0})        例如:db.student.find({}, {_id:0}) # 查询所有数据,不显示_id

                   *查询条件:

                    1.大于 $gt:db.collection_name.find({age: {$gt:18}})

                    2.大于等于 $gte:db.collection_name.find({age: {$gte:18}})

                    3.小于 $lt:db.collection_name.find({age: {$lt:18}})

                    4.小于等于 $lte:db.collection_name.find({age: {$lte:18}})

                    5.不等于 $ne:db.collection_name.find({age: {$ne:18}})

                    *逻辑运算:

                    1.$and : db.collection_name.find({$and:[codition, codition]})

                        # 查询年龄大于18的男学生

                        db.student.find({$and:[{age: {$gt:18}},{sex: '男'}]})

                      2.$or:db.collection_name.find({$or:[codition, codition]})

                       *排序:

                         sort({key:1/-1}) 表示通过字段key进行排序,-1代表倒序

                          # 按照年龄从大到小排序 

                          db.student.find().sort({age:-1})

                        *获取多条数据:db.student.find().limit(3) #获取3条

                        *跳过?条数据:db.student.find().skip(1)  #跳过1条

                3)文档删除:

                        1.删除集合中的所有文档:db.collection_name.remove({})

                        2.删除满足条件的所有文档:db.collection_name.remove(conditon)

                               db.student.remove({_id: 1})

                        3.删除满足条件的第一条文档:db.collection_name.remove(conditon,{justOne:True})

            4) 文档修改:

·                    1.全文档替换

                        db.collection_name.update(codition, doc1)

                       #将id为1的文档,替换成{'name':'test'}

                       db.student.update({_id:1}, {'name':'test'})

                    2.指定字段修改 db.collection_name.update(condition, {$set:{age:100}})

                        1.修改找到的第一条:只会修改找到的第一条

                        # 查找 年龄是18的学生,并修改第一个

                        db.student.update({'age':18},{$set:{sex: '男'}})

                2.修改符合条件的所有文档 加上一个参数 {multi:true}

                        db.student.update({'age':18},{$set:{sex: '男'}},{multi:true})

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 210,978评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 89,954评论 2 384
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,623评论 0 345
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,324评论 1 282
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,390评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,741评论 1 289
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,892评论 3 405
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,655评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,104评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,451评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,569评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,254评论 4 328
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,834评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,725评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,950评论 1 264
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,260评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,446评论 2 348

推荐阅读更多精彩内容

  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 31,905评论 2 89
  • 一、MongoDB简介 1.概述 ​ MongoDB是一个基于分布式文件存储的数据库,由C++语言编写。旨在为WE...
    郑元吉阅读 975评论 0 2
  • 一、MongoDB介绍 1、NoSQL:非关系型数据库 在php的世界里,常见的非关系型数据库有memcached...
    宠辱不惊丶岁月静好阅读 631评论 0 3
  • 一、MongoDB简介 概述MongoDB是一个基于分布式文件存储的数据库,由C++语言编写。旨在为WEB应用提供...
    未央_m阅读 711评论 0 1
  • 一、MongoDB简介 概述MongoDB是一个基于分布式文件存储的数据库,由C++语言编写。旨在为WEB应用提供...
    EndEvent阅读 1,160评论 1 4