MongoDB初步

最近处理的都是论坛、博客一类文档型的数据,也想换个数据库试试,刚好看到mongoDB,就试试吧。

系统环境:

系统:windows 7 32bit
mongoDB版本:3.0.4

Windows下安装

从官网下载安装包:https://www.mongodb.org/downloads
mongoDB支持Linux、OS X和Windows系统,注意下载的时候选择好自己的系统版本。从2.2开始不支持XP了,现在最新的是3.0.4版本。可以使用下面两个命令来看自己系统和版本。

wmic os get caption
wmic os get osarchitecture

根据官网的说明,如果系统是Windows Server 2008 R2 或Windows 7的任何版本,都要下载微软发布的一个补丁。地址在:https://support.microsoft.com/zh-cn/kb/2731284

补丁描述为:
在 Windows 7 或 Windows Server 2008 R2 中使用 FlushViewOfFile() 函数清除内存内存映射文件时出现”33”DOS 错误代码

运行

重要提示
MongoDB被设计为运行在可信任的环境中,默认情况下没有启用“安全模式(Secure Mode)”。如果在公网上使用,请启用“安全模式”。

为了理解这个提醒,先用默认方式运行一下MongoDB好了

  1. 创建data目录:mongoDB需要一个data目录来存储数据,默认是在安装目录的根目录下的“\data\db”文件夹,这个需要手动创建,mongoDB不会自动创建。这里把数据存储在“E:\MongoDB\data”下;

  2. 运行mongoDB:安装时选择的默认安装,安装后可执行文件位于“C:\Program Files\MongoDB\Server\3.0\bin”下,进入该目录,执行:
    mongod.exe --dbpath E:\MongoDB\data
    如果目录中有空格,记得在目录两边加引号。现在mongoDB已经在运行了;

  3. 连接到mongoDB:再打开一个命令行工具,进入可执行目录,输入:
    >mongo.exe

添加mongodb为windows服务

  1. 以管理员权限打开命令行;

  2. 目录和配置文件:

之前的data目录定义为”E:\MongoDB\data”,建立一个log文件夹“E:\MongoDB\log”。
利用以下命令建立配置文件:

>echo logpath=E:\MongoDB\log\mongod.log> "E:\MongoDB\mongod.cfg"
>echo dbpath=E:\MongoDB\data>> "E:\MongoDB\mongod.cfg"
  1. 安装服务
sc.exe create MongoDB binPath= "\"C:\Program Files\MongoDB\Server\3.0\bin\mongod.exe\" --service --config=\"E:\MongoDB\mongod.cfg\"" DisplayName= "MongoDB" start= "auto"
  1. 运行/停止服务
net start MongoDB
net stop MongoDB
  1. 删除服务
sc.exe delete MongoDB
### MongoDB 基本概念 MongoDB 是一种基于分布式文件存储的数据库,采用 C++ 编写,专为 Web 应用提供可扩展性和高性能的数据存储解决方案[^1]。 它是一种介于关系型数据库和非关系型数据库之间的产品,在非关系型数据库中功能最为丰富,且具有许多类似于传统关系型数据库的功能特性。 #### 数据存储方式 MongoDB 使用文档模型来存储数据,其中每条记录是一个键值对组成的文档,这种文档形式非常接近 JSON 对象[^3]。 键值对中的字段可以包含其他文档、数组或者文档数组,这使得复杂数据结构能够被自然表示并高效存储。 #### 高可用性与扩展性 为了满足大规模应用的需求,MongoDB 提供了复制集(Replica Set)机制以保障系统的高可用性,理论上可达 99.999% 的可靠性水平[^3]。 同时,通过分片架构(Sharding),MongoDB 能够支持海量数据存储,并允许随着业务增长而无缝扩容[^3]。 #### 开发友好度 由于其基于 JSON 的灵活文档模型,MongoDB 极大地简化了开发过程,减少了编码工作量。 动态模式设计让开发者更易于适应变化莫测的业务需求,从而加速迭代周期。 以下是使用 Java 实现向 MongoDB 中插入一条模拟物联网传感器数据的例子: ```java import com.mongodb.MongoClient; import com.mongodb.client.MongoCollection; import com.mongodb.client.MongoDatabase; import org.bson.Document; public class MongoDBIoTExample { public static void main(String[] args) { // 创建 MongoDB 连接 MongoClient mongoClient = new MongoClient("localhost", 27017); // 获取或创建名为 iot_data 的数据库实例 MongoDatabase database = mongoClient.getDatabase("iot_data"); // 访问或新建 sensor_data 表单(集合) MongoCollection<Document> collection = database.getCollection("sensor_data"); // 准备要存入的一份新纪录 (BSON 文档格式) Document sensorData = new Document() .append("sensor_id", "sensor1") .append("timestamp", new java.util.Date()) .append("temperature", 25.5) .append("humidity", 60); // 执行实际的数据入库操作 collection.insertOne(sensorData); System.out.println("数据已成功插入!"); // 断开客户端链接释放资源 mongoClient.close(); } } ``` 此代码片段展示了如何利用官方驱动程序完成基本 CRUD 操作之一—Create(新增)。 其他如 Update(修改)、Delete(删除)以及 Find(查找)等基础命令也可经由类似的 API 接口调用来达成[^4]。 在交互式环境中比如 `mongo shell` 下执行简单的增删改查语句如下所示: - **增加**: `db.collectionName.insert({key:value})` 或者 `db.collectionName.save({key:value})` - **删除**: `db.collectionName.remove(criteria)` 可选参数 `{justOne:true}` 来决定是否只移除第一条匹配项 - **更新**: `db.collectionName.update(criteria, updateObject)` 设置选项 `{multi:true}` 控制影响多条还是单一记录 - **查询**: `db.collectionName.find(criteria, projection)` 以上便是关于 MongoDB 初步认识的内容概述及其部分核心特性的阐述[^5]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值