MongoDB是一个基于分布式文件存储的开源数据库系统,旨在为WEB应用提供可扩展的高性能数据存储解决方案。MongoDB将数据存储为文档,这些文档是一个由字段和值对(field-value pairs)组成的数据结构,非常类似于JSON对象。MongoDB文档可以相应地存储在集合中,而这些集合保存在数据库中。
一、MongoDB数据库概述
- 面向文档的存储:MongoDB是非关系型数据库,使用JSON形式存储数据。
- 高性能:MongoDB提供高性能的数据插入和查询操作。
- 高可用性:MongoDB支持服务器之间的数据复制,支持自动故障转移。
- 可伸缩性:MongoDB支持自动分片,可以水平扩展。
- 多种语言支持:MongoDB支持多种语言的API,包括Python、Java、C#、JavaScript、Ruby等。
二、Docker部署MongoDB
Docker是一个开源的应用容器引擎,可以用来部署MongoDB。
- 安装Docker
- 拉取MongoDB镜像
docker pull mongo
- 运行MongoDB容器
docker run --name some-mongo -d mongo
三、MongoDB操作语句
- 连接MongoDB
mongo
- 创建/使用数据库
use database_name
- 创建集合(表)
db.createCollection('collection_name')
- 插入文档(数据)
db.collection_name.insert({key: value})
- 查询文档
db.collection_name.find()
- 更新文档
db.collection_name.update({key: value}, {$set: {key: new_value}})
- 删除文档
db.collection_name.remove({key: value})
四、Java应用
- 添加MongoDB Java驱动依赖
<dependency>
<groupId>org.mongodb</groupId>
<artifactId>mongodb-driver-sync</artifactId>
<version>4.5.0</version>
</dependency>
- Java连接MongoDB示例代码
import com.mongodb.client.MongoClients;
import com.mongodb.client.MongoClient;
import com.mongodb.client.MongoDatabase;
public class MongoDBApp {
public static void main(String[] args) {
MongoClient mongoClient = MongoClients.create("mongodb://localhost:27017");
MongoDatabase database = mongoClient.getDatabase("mydatabase");
System.out.println("Connected to database: " + database.getName());
mongoClient.close();
}
}
- Java操作MongoDB示例代码
import com.mongodb.client.MongoClients;
import com.mongodb.client.MongoClient;
import com.mongodb.client.MongoDatabase;
import com.mongodb.client.MongoCollection;
import org.bson.Document;
public class MongoDBApp {
public static void main(String[] args) {
MongoClient mongoClient = MongoClients.create("mongodb://localhost:27017");
MongoDatabase database = mongoClient.getDatabase("mydatabase");
MongoCollection<Document> collection = database.getCollection("mycollection");
Document doc = new Document("name", "Alice").append("age", 24);
collection.insertOne(doc);
Document query = new Document("name", "Alice");
Document result = col