美文网首页mongoDB我爱编程
使用mongo shell管理MongoDB

使用mongo shell管理MongoDB

作者: Coder_不易 | 来源:发表于2017-02-08 17:26 被阅读283次

    1 MongoDB简介

    mongodb是开源的文档数据库,提供了高性能,高可用性和自动伸缩的数据库服务。mongodb不需要使用ORM工具来简化开发。

    1.1 文档(document)

    mongodb的每条记录就是一个文档,文档实际上是一个数据结构,包括属性域(field)和对应的值(value)。mongodb的文档类似JSON对象,每个属性域的值可以是另外一个文档,后者数组,或者包含一系列文档的数组。
    document示例:

    {
       "_id" : ObjectId("54c955492b7c8eb21818bd09"),
       "address" : {
          "street" : "2 Avenue",
          "zipcode" : "10075",
          "building" : "1480",
          "coord" : [ -73.9557413, 40.7720266 ]
       },
       "borough" : "Manhattan",
       "cuisine" : "Italian",
       "grades" : [
          {
             "date" : ISODate("2014-10-01T00:00:00Z"),
             "grade" : "A",
             "score" : 11
          },
          {
             "date" : ISODate("2014-01-16T00:00:00Z"),
             "grade" : "B",
             "score" : 17
          }
       ],
       "name" : "Vella",
       "restaurant_id" : "41704620"
    }
    

    1.2 集合(collection)

    mongodb将文档(document)存储在集合(collection)中,集合类似于关系型数据库中的表(table)。与表不同的是,集合不要求它的文档拥有相同的。
    mongodb中,在集合中的每个文档必须有一个_id属性(唯一性),与关系型数据库表的主键(primary key)类似。


    2 MongoDB Shell

    mongo shell是MongoDB的Javascript交互界面。可以通过mongo shell来查询,更新数据以及进行数据库管理操作。

    mongo shell是MongoDB的一个组件,安装并启动MongoDB后,就可以连接mongo shell管理MongoDB数据库。

    2.1 启动mongo shell

    在启动mongo shell之前,请先启动MongoDB数据库

    启动mongo shell,连接在localhost上默认端口的MongoDB数据库

    • cd <mongodb installation dir>
    • .bin/mongo

    如果已经将<mongodb installation dir>/bin添加到PATH环境变量中,那么直接输入mongo即可启动mongo shell

    mongo命令在不适用任何参数的情况下,将会连接ip为localhost,端口为27017上的MongoDB数据库。可查看参数选项对ip和端口进行配置。

    .mongorc.js

    mongo启动时将会检查HOME($HOME)目录下是否有.mongorc.js文件。如果找到,那么在进入交互界面之前将会首先解析.mongorc.js文件中的内容。当使用mongodb执行Javascript文件,JS表达式,在命令行使用--eval选项或者指定一个.js文件,mongo都会在执行完Javascript后读取.mongorc.js中的内容。可使用--norc选项阻止.mongorc.js文件的载入

    2.2 使用mongo shell

    • 帮助
      help
    • 显示使用的数据库
      db
    • 切换数据库
      use <database>
      列出所有数据库
      show dbs

    可以直接切换到一个不存在的数据库,当第一个向该数据库存储数据时,MongoDB会创建这个数据库。下面的示例将创建myNewDatabase数据库,并且创建myCollection集合

    use myNewDatabase
    db.myCollection.insert({x:1});
    

    如果集合名称包含空格,-字符,或者以数字开头,那么可以使用db['collection']方式访问集合,例如

    db["3test"].find()
    db.getCollection("3test").find()
    

    mongo shell每行只能接收4095个code point(一个Unicode字符时一个code point),如果超出将会截断

    2.3 格式化输入结果

    db.collection.find()方法将会返回一个结果的游标(cursor),如果返回的游标未被使用var进行读取,那么游标将会自动迭代20次,读取符合查询条件的前20个文档。如果未读取完毕,mongo shell将会提示 Type "it" for more

    可使用.pretty()方法对结果进行格式化,例如
    db.myCollection.find().pretty()

    此外,mongo shell还支持以下打印方法

    • print 打印(不进行任何格式化)
    • print(tojson(<obj>)) 打印JSON格式,与printjson()相同
    • printjson() 打印JSON格式,与`print(tojson(<obj>))相同

    多行输入

    如果以[或者{或者(作为行的结尾,那么mongo shell将会在下一行自动添加...,等待对应的】或者}或者)
    如果连续两行...未输入任何内容,那么将会退出等待

    2.4 tab自动完成和其他快捷键

    mongo shell支持快捷键,例如

    • up和down箭头键,可以遍历输入过的命令
    • tab可以自动补全命令

    2.5 退出shell

    输入quit()或者使用ctrl+c

    相关文章

      网友评论

        本文标题:使用mongo shell管理MongoDB

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