Java操作MongoDB(详细)

1年前 (2024-04-27)
MongoDB 不仅可以在令行窗口(CMD)中运行,它还可以与编程语言配使用,本节我们就来介绍一下在 Java 中如何使用 MongoDB。

环境配置

想要在 Java 程序中使用 MongoDB,需要确保您的电脑上已经安装了 MongoDB,并搭建好了 Java 的环境。您可以查看《Java 教程》来了解不同系统下 Java 的安装教程。

另外您还需要确认安装了 MongoDB JDBC 驱动,您可以通过 http://mongodb.github.io/mongo-java-driver/ 来下载版的 mongodb-driver-3.11.2.jar 以及其依赖项 mongodb-driver-core-3.11.2.jar,并将它们包含进 classpath 中。

连接数据库

要连接数据库,首先需要指定要连接的数据库名称,如果数据库不存在的话,MongoDB 则会自动创建它。下面通过简单的代码来演示如何使用 Java 代码连接 MongoDB 数据库:

import com.mongodb.client.MongoDatabase;

import com.mongodb.MongoClient;

import com.mongodb.MongoCredential;

public class ConnectToDB {

public static void main( String args[] ) {

// 创建 MongoDB 连接

MongoClient mongo = new MongoClient( "localhost" , 27017 );

// 连接到 MongoDB

MongoCredential credential;

credential = MongoCredential.createCredential("sampleUser", "myDb", "password".toCharArray());

System.out.println("Connected to the database successfully");

// 访问数据库

MongoDatabase database = mongo.getDatabase("myDb");

System.out.println("Credentials ::"+ credential);

}

}

编译并运行上面的程序,即可创建名为“myDb”的数据库,并输出如下所示的内容:

$javac ConnectToDB.java
$java ConnectToDB
Connected to the database successfully
Credentials ::MongoCredential{
    mechani = null,
    userName = 'sampleUser',
    source = 'myDb',
    password = <hidden>,
    mechaniProperties = {}

}

创建

若要创建,您可以使用 com.mongodb.client.MongoDatabase 类的 createCollection() 方法,示例代码如下:

import com.mongodb.client.MongoDatabase;

import com.mongodb.MongoClient;

import com.mongodb.MongoCredential;

public class CreatingCollection {

public static void main( String args[] ) {

// 创建 MongoDB 连接

MongoClient mongo = new MongoClient( "localhost" , 27017 );

// 连接到 MongoDB

MongoCredential credential;

credential = MongoCredential.createCredential("sampleUser", "myDb", "password".toCharArray());

System.out.println("数据库连接成功");

// 访问数据库

MongoDatabase database = mongo.getDatabase("myDb");

// 创建

database.createCollection("tutorial");

System.out.println("创建成功");

}

}

编译并运行上面的程序,运行结果如下所示:

数据库连接成功

创建成功

获取/选择

要获取/选择数据库中的,您可以使用 com.mongodb.client.MongoDatabase 类的 getCollection() 方法,示例代码如下:

import com.mongodb.client.MongoCollection;

import com.mongodb.client.MongoDatabase;

import org.bson.Document;

import com.mongodb.MongoClient;

import com.mongodb.MongoCredential;

public class selectingCollection {

public static void main( String args[] ) {

// 创建 MongoDB 连接

MongoClient mongo = new MongoClient( "localhost" , 27017 );

// 连接到 MongoDB

MongoCredential credential;

credential = MongoCredential.createCredential("sampleUser", "myDb", "password".toCharArray());

System.out.println("数据库连接成功");

// 访问数据库

MongoDatabase database = mongo.getDatabase("myDb");

// 创建

database.createCollection("tutorial");

System.out.println("创建成功");

// 检索

MongoCollection<Document> collection = database.getCollection("tutorial");

System.out.println("选择成功 tutorial");

}

}

编译并运行上面的程序,运行结果如下所示:

数据库连接成功
创建成功

选择成功 tutorial

插入文档

想要向中插入文档,您可以使用 com.mongodb.client.MongoCollection 类的 insert() 方法,示例代码如下:

import com.mongodb.client.MongoCollection;

import com.mongodb.client.MongoDatabase;

import org.bson.Document;

import com.mongodb.MongoClient;

public class InsertingDocument {

public static void main( String args[] ) {

// 创建 MongoDB 连接

MongoClient mongo = new MongoClient( "localhost" , 27017 );

// 连接到数据库

MongoDatabase database = mongo.getDatabase("myDb");

// 创建

database.createCollection("tutorial");

System.out.println("创建成功");

// 检索

MongoCollection<Document> collection = database.getCollection("tutorial");

System.out.println("选择成功");

Document document = new Document("title", "MongoDB")

.append("description", "database")

.append("likes", 100)

.append("url", "http://www.biancheng网站站点" rel="nofollow" /> 创建成功
选择成功

文档插入成功

查询文档

想要查询中的文档,您可以使用 com.mongodb.client.MongoCollection 类的 find() 方法,此方返回一个游标,因此想要查询中的所有文档您只需要不断迭代此游标即可,示例代码如下:

import com.mongodb.client.FindIterable;

import com.mongodb.client.MongoCollection;

import com.mongodb.client.MongoDatabase;

import java.util.ArrayList;

import java.util.Iterator;

import java.util.List;

import org.bson.Document;

import com.mongodb.MongoClient;

import com.mongodb.MongoCredential;

public class RetrievingAllDocuments {

public static void main( String args[] ) {

// 创建 MongoDB 连接

MongoClient mongo = new MongoClient( "localhost" , 27017 );

// 连接到 MongoDB

MongoCredential credential;

credential = MongoCredential.createCredential("sampleUser", "myDb", "password".toCharArray());

System.out.println("数据库连接成功");

// 连接到数据库

MongoDatabase database = mongo.getDatabase("myDb");

// 检索

MongoCollection<Document> collection = database.getCollection("tutorial");

System.out.println("成功选择了 tutorial");

Document document1 = new Document("title", "MongoDB")

.append("description", "database")

.append("likes", 100)

.append("url", "http://www.biancheng网站站点" rel="nofollow" /> 数据库连接成功
成功选择了 tutorial
Document{{_id=5dce4e9ff68a9c2449e197b2, title=MongoDB, description=database, likes=100, url=http://www.biancheng网站站点" rel="nofollow" />

import com.mongodb.client.FindIterable;

import com.mongodb.client.MongoCollection;

import com.mongodb.client.MongoDatabase;

import com.mongodb.client.model.Filters;

import com.mongodb.client.model.Updates;

import java.util.Iterator;

import org.bson.Document;

import com.mongodb.MongoClient;

import com.mongodb.MongoCredential;

public class UpdatingDocuments {

public static void main( String args[] ) {

// 创建 MongoDB 连接

MongoClient mongo = new MongoClient( "localhost" , 27017 );

// 连接到 MongoDB

MongoCredential credential;

credential = MongoCredential.createCredential("sampleUser", "myDb", "password".toCharArray());

System.out.println("数据库连接成功");

// 连接到数据库

MongoDatabase database = mongo.getDatabase("myDb");

// 检索

MongoCollection<Document> collection = database.getCollection("tutorial");

System.out.println("成功选择了 tutorial");

collection.updateOne(Filters.eq("title", 1), Updates.set("likes", 150));

System.out.println("文档更新成功...");

// 更新后检索文档

// 获取 iterable 对象

FindIterable<Document> iterDoc = collection.find();

int i = 1;

// 获取迭代器

Iterator it = iterDoc.iterator();

while (it.hasNext()) {

System.out.println(it.next());

i++;

}

}

}

编译并运行上面的程序,运行结果如下所示:

数据库连接成功
成功选择了 tutorial
文档更新成功...
Document{{_id=5dce4e9ff68a9c2449e197b2, title=MongoDB, description=database, likes=100, url=http://www.biancheng网站站点" rel="nofollow" />

import com.mongodb.client.FindIterable;

import com.mongodb.client.MongoCollection;

import com.mongodb.client.MongoDatabase;

import com.mongodb.client.model.Filters;

import java.util.Iterator;

import org.bson.Document;

import com.mongodb.MongoClient;

import com.mongodb.MongoCredential;

public class DeletingDocuments {

public static void main( String args[] ) {

// 创建 MongoDB 连接

MongoClient mongo = new MongoClient( "localhost" , 27017 );

// 连接到 MongoDB

MongoCredential credential;

credential = MongoCredential.createCredential("sampleUser", "myDb", "password".toCharArray());

System.out.println("数据库连接成功");

// 访问数据库

MongoDatabase database = mongo.getDatabase("myDb");

// 检索

MongoCollection<Document> collection = database.getCollection("tutorial");

System.out.println("成功选择了 tutorial");

// 删除文档

collection.deleteOne(Filters.eq("title", "MongoDB"));

System.out.println("文档删除成功...");

// 更新后检索文档

// 获取 iterable 对象

FindIterable<Document> iterDoc = collection.find();

int i = 1;

// 获取迭代器

Iterator it = iterDoc.iterator();

while (it.hasNext()) {

System.out.println(it.next());

i++;

}

}

}

编译并运行上面的程序,运行结果如下所示:

数据库连接成功
成功选择了 tutorial
文档删除成功...

Document{{_id=5dce4e9ff68a9c2449e197b3, title=html, description=database, likes=200, url=http://www.biancheng网站站点" rel="nofollow" />

import com.mongodb.client.MongoCollection;

import com.mongodb.client.MongoDatabase;

import org.bson.Document;

import com.mongodb.MongoClient;

import com.mongodb.MongoCredential;

public class DropingCollection {

public static void main( String args[] ) {

// 创建 MongoDB 连接

MongoClient mongo = new MongoClient( "localhost" , 27017 );

// 连接到 MongoDB

MongoCredential credential;

credential = MongoCredential.createCredential("sampleUser", "myDb", "password".toCharArray());

System.out.println("数据库连接成功");

// 访问数据库

MongoDatabase database = mongo.getDatabase("myDb");

// 创建

System.out.println("创建成功");

// 检索

MongoCollection<Document> collection = database.getCollection("tutorial");

// 删除

collection.drop();

System.out.println("删除成功");

}

}

编译并运行上面的程序,运行结果如下所示:

数据库连接成功
创建成功

删除成功

列出所有

要列出数据库中的所有,您需要使用 com.mongodb.client.MongoDatabase 类的 listCollectionNames() 方法,示例代码如下:

import com.mongodb.client.MongoDatabase;

import com.mongodb.MongoClient;

import com.mongodb.MongoCredential;

public class ListOfCollection {

public static void main( String args[] ) {

// 创建 MongoDB 连接

MongoClient mongo = new MongoClient( "localhost" , 27017 );

// 连接到 MongoDB

MongoCredential credential;

credential = MongoCredential.createCredential("sampleUser", "myDb", "password".toCharArray());

System.out.println("数据库连接成功");

// 访问数据库

MongoDatabase database = mongo.getDatabase("myDb");

System.out.println("创建成功");

for (String name : database.listCollectionNames()) {

System.out.println(name);

}

}

}

编译并运行上面的程序,运行结果如下所示:

数据库连接成功
创建成功
myCollection
myCollection1

myCollection5

更多关于 Java 中 MongoDB 的操作可以参考 http://mongodb.github.io/mongo-java-driver/3.0/driver/getting-started/quick-tour/