MongoDB 是近年来十分风行的一个介于关系数据库和非关系数据库之间的解决方案,采取面向文档的分布式设计思路,具备弱小的可扩展性,表构造自在,并且反对丰盛的查问语句和数据类型。时至今日,MongoDB 以其灵便的数据存储形式,逐步成为 IT 行业十分风行的一种非关系型数据库解决方案。

笔者在我的项目中也经验了从零开始学习 MongoDB 数据库的过程,因而想把我学习过程中的一些心得通过文章分享进去。

步骤1 - MongboDB 环境搭建

MongoDB 反对的数据结构十分涣散,是相似 json 的 bson 格局,这种灵便的格局使得 MongoDB 能够存储比较复杂的数据类型。Mongo 最大的特点是它反对的查询语言(Query Language)十分弱小,其语法有点相似于面向对象的查询语言,因而可读性十分好,并且简直能够实现相似关系数据库单表查问的绝大部分性能。

本步骤介绍 MongoDB 学习的第一步:环境搭建。

从 MongoDB 的 官网下载安装包。

我装置在 C 盘的 MyApp 目录下的 mongoDB,装置结束后,bin 文件夹里有好几个执行文件。把 bin 文件门路加到 windows 零碎的环境变量里。

应用如下命令行启动 MongoDB 服务器:

mongod --dbpath C:MyAppmongoDBjerryserverdb
从控制台打印的 console 里看到下列音讯:

Mongo DB starting: pid=16588 port=27017
意思是过程 id 为 16588 的过程启动了 MongoDB,监听端口号为 27017.

console 里还有其余一些有用的提醒,比方:

Read and write access to data and configuration is unrestricted - 没有对数据读写设置权限

WARNING: This server is bound to localhost - 这个服务器通过 localhost 拜访

在 cmd 里用命令 netstat -ano | find "27017", 发现的确过程 id 为 16588 的过程在端口 27017 监听:

关上 MongoDB Compass, 这是 MongoDB GUI 图形化操作界面,在 MongboDB 装置过程中也主动被装置了。

Hostname 输出 localhost,port 输出 27017,点击 Connect 进行连贯:

连贯之后,在 admin 数据库下创立一个新的 Collection:

我的例子里,collection 名称为 person,点 INSERT DOCUMENT 创立一条记录, _id 为 MongoDB compass 主动生成的, 另一个字段的名称为 name, 值为 "Jerry":

再点一次 INSERT DOCUMENT, 生成两条 person 记录。

当初咱们新开另一个命令提示行窗口来生产在 MongoDB Compass 里创立的两条 person 记录。

命令行 mongo localhost:27017/admin, 意思是连贯这个数据库里的 admin 数据库

此时从前一个启动 MongoDB 服务器的命令提示行的控制台输入,能看到 connection accepted from 的输入:

命令行 db.person.find(), 打印出了 admin 数据库里 person 表里的两条记录,阐明咱们环境配置胜利了。

步骤2 - 应用 Node.js 拜访 MongoDB

在 localhost:27017 的服务器上,在数据库 admin 上面创立了一个名为 person 的数据库表,并插入了两条记录:

上图是用 MongoDB Compass 查看的胜利插入的两条记录。
上面咱们用 Node.js 读取这两条记录。
首先在命令行里执行 npm install mongodb,
而后新建一个 JavaScript 文件,复制以下内容:

留神第 12 行的 dbo.collection("person"). find({}).toArray,意思是读取表 person 里的所有记录。

var MongoClient = require('mongodb').MongoClient;var url = "mongodb://localhost:27017";MongoClient.connect(url, function(err, db) {    if (err){        console.log(err);        throw err;    }    console.log("Jerry DB connection established!");    var dbo = db.db("admin");    dbo.collection("person"). find({    }    ).toArray(function(err, result) {        if (err)        throw err;        console.log(result);        db.close();    }    );    db.close();});

如果我只想读取 name 为 Jerry 的那条记录,只须要把 where 条件传入办法 find 即可:

从调试器里能察看到依照冀望的形式被读取回来了:

步骤3 - 应用 Java 代码往 MongoDB 里插入数据

如果您是基于 Maven 进行依赖治理的 Java 我的项目,只须要在您的 pom.xml 里退出上面的依赖定义:

<dependency><groupId>org.mongodb</groupId><artifactId>mongodb-driver</artifactId><version>3.6.4</version></dependency>

而后应用命令行 mvn clean install 后,您的本地 maven 仓库里会多出三个和用 Java 连贯 MongoDB 相干的库:

  • bson
  • mongodb-driver
  • mongodb-driver-core

当然也能够手动逐个下载 jar 文件:https://mongodb.github.io/mon...

本文应用的是这三个文件,将它们下载到本地,再退出 Java 我的项目的 classpath 里。

Java 代码如下:

package mongoDB;import java.util.ArrayList;import java.util.List;import org.bson.Document;import com.mongodb.MongoClient;import com.mongodb.client.FindIterable;import com.mongodb.client.MongoCollection;import com.mongodb.client.MongoCursor;import com.mongodb.client.MongoDatabase;public class MongoDBTest {    private static void insert(MongoCollection<Document> collection) {        Document document = new Document("name", "dog");        List<Document> documents = new ArrayList<Document>();        documents.add(document);        collection.insertMany(documents);    }    public static void main(String args[]) {        MongoClient mongoClient = null;        try {            mongoClient = new MongoClient("localhost", 27017);            MongoDatabase mongoDatabase = mongoClient.getDatabase("admin");            System.out.println("Connect to database successfully");            MongoCollection<Document> collection = mongoDatabase            .getCollection("person");            // insert(collection);            FindIterable<Document> findIterable = collection.find();            MongoCursor<Document> mongoCursor = findIterable.iterator();            while (mongoCursor.hasNext()) {                System.out.println(mongoCursor.next());            }        }        catch (Exception e) {            System.err.println(e.getClass().getName() + ": " + e.getMessage());        }        finally{            mongoClient.close();        }    }}

和本教程步骤 2相比,上述代码的 insert 办法里还展现了如何用 Java 代码给 MongoDB 数据库里减少记录。

private static void insert(MongoCollection<Document> collection) {    Document document = new Document("name", "dog");    List<Document> documents = new ArrayList<Document>();    documents.add(document);    collection.insertMany(documents);}

执行 Java 利用,发现通过 insert 办法加到数据库的记录也能被顺利读出来。

总结

MongoDB 是近年来十分风行的一个介于关系数据库和非关系数据库之间的解决方案,采取面向文档的分布式设计思路,具备弱小的可扩展性,表构造自在,并且反对丰盛的查问语句和数据类型。本文首先介绍了 MongoDB 的本地环境搭建步骤,接着别离介绍了应用 Node.js 和 Java 对本地 MongoDB 进行数据读写的编程细节。