MongoDB With Jav

本文作者:杨龙,叩丁狼高级讲师。原创文章,转载请注明出处。

准备工作

要使用 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 之前需让程序先与数据库建立起链接。

MongoDB With Jav_第1张图片

// 身份认证连接
MongoClient mongoClient = MongoClients.create("mongodb://root:12345@localhost/?authSource=admin");
System.out.println(mongoClient);
// 断开链接
mongoClient.close();

Database 操作 和 Collection 操作

MongoDB With Jav_第2张图片

// 获取所有的 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

Document 操作

Document 类

org.bson.Document 类,用来封装文档数据的。
com.mongodb.client.model.Updates 类,提供创建 BSON 类型的更新文档(包含操作符),以确定修改修改的字段及值。。
com.mongodb.client.model.Filters 类,提供创建 BSON 类型的过滤器,以过滤文档。
com.mongodb.client.model.Sorts 类,用来构建排序的。

使用 Collection 对象的的方法来操作:

  • insertOne: 插入一个文档
  • insertMany: 插入多个文档
// 创建文档对象
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 对象的的方法来操作:

  • insertOne: 插入一个文档
  • insertMany: 插入多个文档

注意:_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 对象的的方法来操作:

  • deleteOne: 删除一个文档
  • deleteMany: 删除多个文档
// 按条件删除一个文档
persons.deleteOne(Filters.eq("age", 50));
// 按条件删除多个文档
persons.deleteMany(Filters.eq("age", 50));

// 根据 id 删除文档
persons.deleteOne(Filters.eq("_id", new ObjectId("5ce4e9806897ec3b938526c9")))

使用 Collection 对象的的方法来操作:

  • find: 查询文档
  • countDocuments: 查询文档数量
// 查询所有文档
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);
}

你可能感兴趣的:(Java基础,Java,MongoDB数据库,Database,Collection)