概述

MongoDB是一个跨平台,面向文档的数据库。MongoDB创建的数据库可以实现高可用性,高性能,并且能够轻松拓展。 MongodbDB的运行方式主要给予两个概念:集合(collection)和文档(document)

数据库

数据库就是集合的实际容器

集合

集合就是一组MongoDB文档,相当于关系型数据库的表。

文档

文档就是一组键-值对,类似于JSON对象。文档有着动态的模式,这意味着同一集合内的文档不需要具有同样的字段或结构。

关系型数据库与MongoDB数据库在一些术语上的对比

位的字符串,由一组十六进制的字符组成,每个字节两位的十六进制数字,总共用了12字节的存储空间。保障了数据库文档的唯一性!

官方针对ObjectId的规范

  • 位进行提取,然后按照十六进制转为十进制,这个数字就是一个时间戳。
  • Machine 机器。接下来的三个字节就是所在主机的唯一标识符,一般是机器主机名的散列值,这样就确保了不同主机生成不同的机器hash值,确保在分布式中不造成冲突,这也就是在同一台机器生成的objectId中间的字符串都是一模一样的原因。
  • PID 进程ID。上面的Machine是为了确保在不同机器产生的objectId不冲突,而pid就是为了在同一台机器不同的mongodb进程产生了objectId不冲突,接下来的两位就是产生objectId的进程标识符。
  • 的3次方等于16777216条记录的唯一性。

private static readonly int __staticMachine = (GetMachineHash() + GetAppDomainId()) & 0x00ffffff;

private static readonly short __staticPid = GetPid();

private static int __staticIncrement = (new Random()).Next();

 

// public static methods

/// <summary>

/// Generates a new ObjectId with a unique value.

/// </summary>

/// <returns>An ObjectId.</returns>

public static ObjectId GenerateNewId()

{

    return GenerateNewId(GetTimestampFromDateTime(DateTime.UtcNow));

}

 

/// <summary>

/// Generates a new ObjectId with a unique value (with the timestamp component based on a given DateTime).

/// </summary>

/// <param name="timestamp">The timestamp component (expressed as a DateTime).</param>

/// <returns>An ObjectId.</returns>

public static ObjectId GenerateNewId(DateTime timestamp)

{

    return GenerateNewId(GetTimestampFromDateTime(timestamp));

}

 

/// <summary>

/// Generates a new ObjectId with a unique value (with the given timestamp).

/// </summary>

/// <param name="timestamp">The timestamp component.</param>

/// <returns>An ObjectId.</returns>

public static ObjectId GenerateNewId(int timestamp)

{

    int increment = Interlocked.Increment(ref __staticIncrement) & 0x00ffffff; // only use low order 3 bytes

    return new ObjectId(timestamp, __staticMachine, __staticPid, increment);

}

 

MongoDB 支持如下数据类型:

字节的唯一 ID,

{"Key" :ObjectId() }

Boolean

布尔值。用于存储布尔值(真/假)。

{"Key":false}

Date

日期时间。用 UNIX 时间格式来存储当前日期或时间。你可以指定自己的日期时间:创建 Date 对象,传入年月日信息。

{"Key" : new Date()}

Timestamp

时间戳。记录文档修改或添加的具体时间。

{"Key":new Timestamp()}

Regular Expression

正则表达式类型。用于存储正则表达式

采用JavaScript的正则表达式语法:{"Key":/[0-9]{1,2}/}

MaxKey

BSON包括一个特殊类型,表示可能的最大值。

mongodb shell不支持

注意事项:

  • MongoDB不支持表联查(Join)操作,如有相应需求建议通过内嵌文档实现!
  • mongodb 是默认区分大小写的,建议mongodb 的表名和字段名都用小写字母命名
  • 尽量缩短字段名称的长度,由于MongoDB机制的问题导致每笔数据在存储时都会保存他的Key和Value,这样就造成了大量的数据冗余,对应的存储也占用较大的空间
  • ,索引名的长度不能超过125个字符,一个符合索引最多只能有31个

 

MongoDB学习笔记——概述的更多相关文章

  1. MongoDB学习笔记系列

    回到占占推荐博客索引 该来的总会来的,Ef,Redis,MVC甚至Sqlserver都有了自己的系列,MongoDB没有理由不去整理一下,这个系列都是平时在项目开发时总结出来的,希望可以为各位一些帮助 ...

  2. PHP操作MongoDB学习笔记

    <?php/*** PHP操作MongoDB学习笔记*///*************************//**   连接MongoDB数据库  **////*************** ...

  3. MongoDB 学习笔记(原创)

    MongoDB 学习笔记 mongodb 数据库 nosql 一.数据库的基本概念及操作 SQL术语/概念 MongoDB术语/概念 解释/说明 database database 数据库 table ...

  4. mongoDB 学习笔记纯干货(mongoose、增删改查、聚合、索引、连接、备份与恢复、监控等等)

    最后更新时间:2017-07-13 11:10:49 原始文章链接:http://www.lovebxm.com/2017/07/13/mongodb_primer/ MongoDB - 简介 官网: ...

  5. MongoDB学习笔记(转)

    MongoDB学习笔记(一) MongoDB介绍及安装MongoDB学习笔记(二) 通过samus驱动实现基本数据操作MongoDB学习笔记(三) 在MVC模式下通过Jqgrid表格操作MongoDB ...

  6. 【转】MongoDB学习笔记(查询)

    原文地址 MongoDB学习笔记(查询) 基本查询: 构造查询数据. > db.test.findOne() { "_id" : ObjectId("4fd58ec ...

  7. MongoDB学习笔记(六)--复制集+sharding分片 && 总结

    复制集+sharding分片                                                               背景 主机 IP 服务及端口 Server A ...

  8. MongoDB学习笔记(五)--复制集 && sharding分片

    主从复制                                                                                       主从节点开启 主节 ...

  9. MongoDB学习笔记(四)--索引 && 性能优化

    索引                                                                                             基础索引 ...

随机推荐

  1. oracle12c之一 控制-PDB的磁盘I/O(IOPS,MBPS)资源管理

    在以前的版本中,没有简单的方法来控制单个PDB使用的磁盘I / O量. 因此,某个PDB可能耗尽大量磁盘I / O,并影响同一实例中的其他PDB的性能. Oracle 12c R2可以控制PDB使用的 ...

  2. 实现接口必须要加注解@Override吗

    不一定的,但是我们的编译器在查询我们重写的方法,方法名,参数,返回类型的时候,是能够根据注解来帮助我们判断方法重写的正确与否 所以我们有必要在编写过程中加上@Override,虽然我们的eclipse ...

  3. 关于DES加密强制更新版(4.22)

    数据加密算法(Data Encryption Algorithm,DEA)是一种对称加密算法,很可能是使用最广泛的密钥系统,特别是在保护金融数据的安全中,最初开发的DEA是嵌入硬件中的.通常,自动取款 ...

  4. Java - 二分法查找(尚学堂第七章数组)

    import java.util.Arrays; public class TestBinarySearch { public static void main(String[] args) { in ...

  5. Java - 自定义异常(尚学堂第六章异常机制作业计算平均数)

    编写一个计算N个学生分数平均分的程序.程序应该提示用户输入N的值,如何必须输入所有N个学生分数.如果用户输入的分数是一个负数,则应该抛出一个异常并捕获,提示“分数必须是正数或者0”.并提示用户再次输入 ...

  6. 生成随机32位Token43位asekey

    // 生成随机32位Token字符和43位AseKey var arr = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', ' ...

  7. JWT(Json Web Token)初探与实践

    前言什么是JWT?为什么使用JWT?什么时候使用JWT?JWT的基本结构HeaderPayloadSignature将他们放在一起项目实践JWT后端前端关于安全性总结参考 协议标准:https://t ...

  8. React 同构开发(二)

    React 同构 所谓同构,简单的说就是客户端的代码可以在服务端运行,好处就是能极大的提升首屏时间,避免白屏,另外同构也给SEO提供了很多便利. React 同构得益于 React 的虚拟 DOM.虚 ...

  9. python中函数参数传递的几种方法

    转自  http://www.douban.com/note/13413855/ Python中函数参数的传递是通过“赋值”来传递的.但这条规则只回答了函数参数传递的“战略问题”,并没有回答“战术问题 ...

  10. c#静态扩展方法,字典的克隆扩展方法

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...