本文作者:杨龙,叩丁狼高级讲师。原创文章,转载请注明出处。
要使用 Java 代码操作 MongoDB 数据库,创建 Maven 项目则先添加 MongoDB 的 Java 驱动依赖.
<dependency>
<groupId>org.mongodbgroupId>
<artifactId>mongodb-driverartifactId>
<version>3.10.2version>
dependency>
<dependency>
<groupId>junitgroupId>
<artifactId>junitartifactId>
<version>4.12version>
<scope>testscope>
dependency>
与使用 Java 代码操作 MySQL 数据库一样,在执行 CRUD 之前需让程序先与数据库建立起链接。
// 身份认证连接
MongoClient mongoClient = MongoClients.create("mongodb://root:12345@localhost/?authSource=admin");
System.out.println(mongoClient);
// 断开链接
mongoClient.close();
// 获取所有的 Database 名称
MongoIterable<String> databaseNames = mongoClient.listDatabaseNames();
for (String databaseName : databaseNames) {
System.out.println(databaseName);
}
// 根据名字获取 Database,若不存在后续往这个库操作前会自动创建名字为 test 的 Database
MongoDatabase testDatabase = mongoClient.getDatabase("test");
// 删除 Database:MongoDatabase 对象的的方法 drop()
// 据名字获取 Collection,若不存在后续往这个库操作前会自动创建名字为 persons 的 Collection
MongoCollection<Document> persons = testDatabase.getCollection("persons");
// 创建 Collection:MongoDatabase 对象的方法 createCollection
// 删除 Collection:MongoCollection 对象的方法 drop
org.bson.Document 类,用来封装文档数据的。
com.mongodb.client.model.Updates 类,提供创建 BSON 类型的更新文档(包含操作符),以确定修改修改的字段及值。。
com.mongodb.client.model.Filters 类,提供创建 BSON 类型的过滤器,以过滤文档。
com.mongodb.client.model.Sorts 类,用来构建排序的。
使用 Collection 对象的的方法来操作:
// 创建文档对象
Document document = new Document();
// 设置字段及值
document.append("name", "刘备")
.append("age", 41);
// 保存文档,保存后文档对象 _id 属性有值
persons.insertOne(document);
Document document1 = new Document();
document1.append("name", "关羽")
.append("age", 37);
Document document2 = new Document();
document2.append("name", "张飞")
.append("age", 34);
List<Document> collections = new ArrayList<>();
collections.add(document1);
collections.add(document2);
// 批量保存文档
persons.insertMany(collections);
使用 Collection 对象的的方法来操作:
注意:_id 字段的值是不可以修改。
// 改一条,第一个参数匹配条件,第二个参数要修改的字段
persons.updateOne(Filters.eq("name", "刘备"), Updates.set("age", 43));
// 同时改多个字段值
persons.updateOne(Filters.eq("name", "刘备"), Updates.combine(Updates.set("age", 46), Updates.set("name", "曹操")));
// 根据 _id 修改文档
persons.updateOne(Filters.eq("_id", new ObjectId("5ce4e9806897ec3b938526c9")), Updates.set("name", "张辽"));
// 改多条,第一个参数匹配条件,第二个参数要修改的字段
persons.updateMany(Filters.eq("name", "刘备"), Updates.set("age", 43));
// 修改所有文档对象
persons.updateMany(new Document(), Updates.set("age", 43));
使用 Collection 对象的的方法来操作:
// 按条件删除一个文档
persons.deleteOne(Filters.eq("age", 50));
// 按条件删除多个文档
persons.deleteMany(Filters.eq("age", 50));
// 根据 id 删除文档
persons.deleteOne(Filters.eq("_id", new ObjectId("5ce4e9806897ec3b938526c9")))
使用 Collection 对象的的方法来操作:
// 查询所有文档
FindIterable<Document> docs1 = persons.find();
for (Document doc : docs1) {
System.out.println(doc);
}
// 根据条件查询文档
FindIterable<Document> docs2 = persons.find(Filters.eq("age", 41));
for (Document doc : docs2) {
System.out.println(doc);
}
// 根据条件查询文档数量
long count = persons.countDocuments(Filters.eq("age", 41));
System.out.println(count);
// 分页排序查询文档
FindIterable<Document> docs3 = persons.find()
.skip(5).limit(5) // 分页部分
.sort(Sorts.ascending("age")); // 排序部分
for (Document doc : docs3) {
System.out.println(doc);
}