MongoDB的简单入门

作者: Xue_Season | 来源:发表于2015-03-28 14:18 被阅读3051次

    MongoDB的基本概念

    • MongoDB的数据单元是文档,可以看作JavaScript中的对象,类似于关系数据库中的行。
    • 集合(Collection)类似于关系数据库中的表,区别在于没有模式。
    • 每个MongoDB数据库都自身的集合和权限。
    • MongoDB的操作主要靠终端的JavaScript Shell完成。

    文档

    在JavaScript中,文档表示为对象:

    {"name": "XueSeason", "age": 22}
    

    以上文档有一个name键,其值为XueSeason,age键值为22
    从这个文档,解释了几个概念:

    • 文档中的键值对是有序的,上面例子中如果调换name和age的键值对,将会被视为一个新的文档。
    • 文档中的值不仅仅只限于字符串形式,还有其他更高级的类型。
    • 文档的键使用UTF-8字符。其中.$通常被保留,只有在特定环境下使用,_也是保留的。

    集合

    集合就是文档集,作为NoSQL是区别于关系数据库的表。

    无模式

    集合是无模式的。即不同类型的文档可以共存于同一个集合中:

    {"name": "XueSeason", "age": 22}
    {"book": "The old man and the Sea"}
    

    注意上面的文档是完全不同的两个文档。既然一个集合可以容纳各种类型,为何需要多集合?
    使用多集合的意义在于:

    • 降低熵值。即减少混乱程度。
    • 速度上的优越性。把一个特定类型的文档分成多个子集合提高查询效率。
    • 把同种类型的文档存在一个集合汇总,使数据更集中。

    推荐尽量使用子集合来组织数据。

    命名

    • 集合名不能为空字符串。
    • 不能含有\0字符。
    • 不能以system.开头,系统集合的保留前缀。
    • 不能含有保留字符$

    启动MongoDB

    确保你成功安装MongoDB并且正确配置。
    终端输入mongod命令。

    如果出现类似以下信息:

    2015-03-28T13:35:04.067+0800 W -        [initandlisten] Detected unclean shutdown - /data/db/mongod.lock is not empty.
    2015-03-28T13:35:04.067+0800 I STORAGE  [initandlisten] exception in initAndListen: 98 Unable to lock file: /data/db/mongod.lock errno:35 Resource temporarily unavailable. Is a mongod instance already running?, terminating
    2015-03-28T13:35:04.067+0800 I CONTROL  [initandlisten] dbexit:  rc: 100
    

    表明已经有一个MongoDB程序在后台运行。
    可以通过ps -ef查找到相关的pid,执行kill [pid]强制关闭。

    MongoDB在没有参数的情况下默认会使用/data/db目录,并监听27017端口。
    如果该目录不存在或者不可写,服务器也会启动失败。

    MongoDB Shell

    运行mongo启动shell:

    xuejijiedeMacBook-Pro:~ xuejijie$ mongo
    MongoDB shell version: 3.0.1
    connecting to: test
    > 
    

    此时,你可以用REPL方式执行JavaScript代码。

    MongoDB客户端

    MongoDB Shell的真正强大不仅在于是一个JavaScript的解释器,而且还是一个MongoDB客户端。
    开启的时候,shell会连到MongoDB服务器的test数据库,并将这个数据库连接赋值给全局变量db

    选择数据库:

    > use mydatabase
    switched to db mydatabase
    > db
    mydatabase
    

    CRUD

    接下来学习下操作数据的4个基本操作。

    创建

    使用insert函数,可以添加文档到对应的集合中。

    > post = { "title": "The first day", "content": "It is awesome time", "date": new Date()}
    {
        "title" : "The first day",
        "content" : "It is awesome time",
        "date" : ISODate("2015-03-28T05:53:16.355Z")
    }
    > db.blog.insert(post)
    WriteResult({ "nInserted" : 1 })
    > db.blog.find()
    { "_id" : ObjectId("551641e5b1f58081c3b9d7ea"), "title" : "The first day", "content" : "It is awesome time", "date" : ISODate("2015-03-28T05:53:16.355Z") }
    

    上述操作首先创建一个post对象,然后通过insert方法将数据存放到blog集合中,最后通过find函数,展示blog集合中的所有文档。

    此时文档多了额外的键_id,是系统自动添加的主键。

    读取

    find会返回集合的所有文档。若只想查看一个文档,可以用findOne
    关于更多查询内容,将作为新的文章讲解。

    更新

    update函数接受两个参数:所更新文档的限定条件,新的文档。

    > post.comment = []
    [ ]
    > db.blog.update({title: "The first day"}, post)
    WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
    > db.blog.find()
    { "_id" : ObjectId("551641e5b1f58081c3b9d7ea"), "title" : "The first day", "content" : "It is awesome time", "date" : ISODate("2015-03-28T05:53:16.355Z"), "comment" : [ ] }
    

    删除

    remove函数永久删除文档,如果无参,就会删除集合内的所有文档。也可以接受限定条件删除指定内容。

    更多shell指令可以通过help查看,或者参考官方doc。

    原文博客

    相关文章

      网友评论

      • Xue_Season:因为今天github受到DDos攻击,原博的文章无法同步到Github pages上,所以链接暂时不能访问。

      本文标题:MongoDB的简单入门

      本文链接:https://www.haomeiwen.com/subject/znynxttx.html