zoukankan      html  css  js  c++  java
  • 【二】MongoDB入门

    下面是mongodb的一些基本概念:

    • 文档是MongoDB中数据的基本单元,类似关系数据库中的行。
    • 集合,是存储文档的容器,类似关系数据库中的表。
    • MongoDB的单个实例容纳多个数据库,每个数据库都有自己的集合和权限。
    • 每一个文档都有一个特殊的“_id”,它在文档所处的集合中是唯一的。

    为了易于理解,咱们把MongoDB中的概念与关系数据库对比一下:

     一、文档

    文档是mongodb的核心概念。多个键值有序的放置在一起便是文档。简单的例子:

    1   {"greeting":"Hello World","foo":15}   
    2   {"foo":15,"greeting":"Hello World"}
    3   {"foo":15}
    4   {"Foo":15}
    5 {"Foo":"15"}
    • 键名:不能含有空格及特殊字符'$'和'.',同时以下划线开头的键是保留的
    • 键名区分大小写,如上述的3和4是不同的文档
    • 文档中键名不能重复
    • 文档区别类型,如上述的4和5,值的类型不一样所以属于不同的文档
    • 键的值不仅是字符串还可以是其他类型

    二、集合

    集合就是一组文档,如果说文档如关系数据库中的行,那么集合就如同表。集合有如下特点:

    1、无模式

    集合是无模式的,这意味着集合里可以存储各种各样的文档。那么是不是mongodb中只需要一个集合就可以了呢?答案是否,下面是一些理由:

    • 易于管理:如果各种各样的文档都放到一个集合中,那么对于开发者或管理员都是噩梦。
    • 提高效率:在一个集合中查不同类型的文档,速度上肯定不如各个单独类型的集合快。
    • 提高索引效率

    2、命名

    我们可以名字来标识集合,下面是一些约束:

    • 不能为空字符串,如""
    • 不能含有空格
    • 不能以system.开头,这是系统保留前缀
    • 不能含有特殊字符,如$

    组织集合的一种常用惯例是按命名空间划分子集合,比如开发一个博客

    三、数据库

    数据库包括多个集合,一个实例中包括多个数据库,一般一个应用对应一个数据库。数据库的命名规则:

    • 不能是空字符串
    • 不能包括空格等特殊字符
    • 应该全部小写
    • 不能使用系统预留的,如admin,local,config

    关于数据库的相关操作:

    #查看当前数据库
    > db
    test
    #切换当前数据库
    > use local
    switched to db local
    > db
    local

     获得帮助:

    > help
        db.help()                    help on db methods
        db.mycoll.help()             help on collection methods
        sh.help()                    sharding helpers
        rs.help()                    replica set helpers
        help admin                   administrative help
        help connect                 connecting to a db help
        help keys                    key shortcuts
        help misc                    misc things to know
        help mr                      mapreduce
    
        show dbs                     show database names
        show collections             show collections in current database
        show users                   show users in current database
        show profile                 show most recent system.profile entries with time >= 1ms
        show logs                    show the accessible logger names
        show log [name]              prints out the last segment of log in memory, 'global' is default
        use <db_name>                set current database
        db.foo.find()                list objects in collection foo
        db.foo.find( { a : 1 } )     list objects in foo where a == 1
        it                           result of the last line evaluated; use to further iterate
        DBQuery.shellBatchSize = x   set default number of items to display on shell
        exit                         quit the mongo shell
    > 
  • 相关阅读:
    数据结构的入门
    Google 插件
    树莓派的第一次
    MySQL下载与安装
    SVN图标不显示问题
    excel 批量生成SQL语句
    版本管理工具
    RSA加密、解密、签名、验签的原理及方法
    获取客户端内网IP
    eclipse 添加svn插件
  • 原文地址:https://www.cnblogs.com/mysql-dba/p/5033732.html
Copyright © 2011-2022 走看看