数据库的信息是存储在集合中。它们使用了系统的命名空间:
讯享网
在MongoDB数据库中名字空间 <dbname>.system.* 是包含多种系统信息的特殊集合(Collection),如下:
讯享网 <th>描述</th> </tr><tr><td>dbname.system.namespaces</td> <td>列出所有名字空间。</td> </tr><tr><td>dbname.system.indexes</td> <td>列出所有索引。</td> </tr><tr><td>dbname.system.profile</td> <td>包含数据库概要(profile)信息。</td> </tr><tr><td>dbname.system.users</td> <td>列出所有可访问数据库的用户。</td> </tr><tr><td>dbname.local.sources</td> <td>包含复制对端(slave)的服务器信息和状态。</td> </tr></tbody></div><p>对于修改系统集合中的对象有如下限制。</p> 在{{system.indexes}}插入数据,可以创建索引。但除此之外该表信息是不可变的(特殊的drop index命令将自动更新相关信息)。
{{system.users}}是可修改的。 {{system.profile}}是可删除的。
下表为MongoDB中常用的几种数据类型。
<th>描述</th> </tr><tr><td>String</td> <td>字符串。存储数据常用的数据类型。在 MongoDB 中,UTF-8 编码的字符串才是合法的。</td> </tr><tr><td>Integer</td> <td>整型数值。用于存储数值。根据你所采用的服务器,可分为 32 位或 64 位。</td> </tr><tr><td>Boolean</td> <td>布尔值。用于存储布尔值(真/假)。</td> </tr><tr><td>Double</td> <td>双精度浮点值。用于存储浮点值。</td> </tr><tr><td>Min/Max keys</td> <td>将一个值与 BSON(二进制的 JSON)元素的最低值和最高值相对比。</td> </tr><tr><td>Array</td> <td>用于将数组或列表或多个值存储为一个键。</td> </tr><tr><td>Timestamp</td> <td>时间戳。记录文档修改或添加的具体时间。</td> </tr><tr><td>Object</td> <td>用于内嵌文档。</td> </tr><tr><td>Null</td> <td>用于创建空值。</td> </tr><tr><td>Symbol</td> <td>符号。该数据类型基本上等同于字符串类型,但不同的是,它一般用于采用特殊符号类型的语言。</td> </tr><tr><td>Date</td> <td>日期时间。用 UNIX 时间格式来存储当前日期或时间。你可以指定自己的日期时间:创建 Date 对象,传入年月日信息。</td> </tr><tr><td>Object ID</td> <td>对象 ID。用于创建文档的 ID。</td> </tr><tr><td>Binary Data</td> <td>二进制数据。用于存储二进制数据。</td> </tr><tr><td>Code</td> <td>代码类型。用于在文档中存储 JavaScript 代码。</td> </tr><tr><td>Regular expression</td> <td>正则表达式类型。用于存储正则表达式。</td> </tr></tbody></div><p>下面说明下几种重要的数据类型。</p>
ObjectId 类似唯一主键,可以很快的去生成和排序,包含 12 bytes,含义是:
- 前 4 个字节表示创建 unix 时间戳,格林尼治时间 UTC 时间,比北京时间晚了 8 个小时
讯享网<li>接下来的 3 个字节是机器标识码</li> <li>紧接的两个字节由进程 id 组成 PID</li> <li>最后三个字节是随机数</li>
MongoDB 中存储的文档必须有一个 _id 键。这个键的值可以是任何类型的,默认是个 ObjectId 对象
由于 ObjectId 中保存了创建的时间戳,所以你不需要为你的文档保存时间戳字段,你可以通过 getTimestamp 函数来获取文档的创建时间:
ObjectId 转为字符串
讯享网
BSON 字符串都是 UTF-8 编码。
BSON 有一个特殊的时间戳类型用于 MongoDB 内部使用,与普通的 日期 类型不相关。 时间戳值是一个 64 位的值。其中:
- 前32位是一个 time_t 值(与Unix新纪元相差的秒数)
<li>后32位是在某秒中操作的一个递增的</li>
在单个 mongod 实例中,时间戳值通常是唯一的。
在复制集中, oplog 有一个 ts 字段。这个字段中的值使用BSON时间戳表示了操作时间。
BSON 时间戳类型主要用于 MongoDB 内部使用。在大多数情况下的应用开发中,你可以使用 BSON 日期类型。
表示当前距离 Unix新纪元(1970年1月1日)的毫秒数。日期类型是有符号的, 负数表示 1970 年之前的日期。
讯享网
这样创建的时间是日期类型,可以使用 JS 中的 Date 类型的方法。
返回一个时间类型的字符串:
讯享网
或者
MongoDB 创建数据库的语法格式如下:
讯享网
如果数据库不存在,则创建数据库,否则切换到指定数据库。
以下实例我们创建了数据库 runoob:
如果你想查看所有数据库,可以使用 show dbs 命令:
讯享网
可以看到,我们刚创建的数据库 runoob 并不在数据库的列表中, 要显示它,我们需要向 runoob 数据库插入一些数据。

MongoDB 中默认的数据库为 test,如果你没有创建新的数据库,集合将存放在 test 数据库中。
注意: 在 MongoDB 中,集合只有在内容插入后才会创建! 就是说,创建集合(数据表)后要再插入一个文档(记录),集合才会真正创建。
MongoDB 删除数据库的语法格式如下:
讯享网
删除当前数据库,默认为 test,你可以使用 db 命令查看当前数据库名。
以下实例我们删除了数据库 runoob。
首先,查看所有数据库:
接下来我们切换到数据库 runoob:
讯享网
执行删除命令:
最后,我们再通过 show dbs 命令数据库是否删除成功:
讯享网
集合删除语法格式如下:
以下实例删除了 runoob 数据库中的集合 site:
讯享网

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/149337.html