四.MongoDB入门-Java操作MongoDB

本文涉及的产品
云数据库 MongoDB,通用型 2核4GB
简介: MongoDB入门-Java操作MongoDB

MongDD的语法很多,我们只需要记一些常用的即可,在实际开发中还是使用Java面向对象的方式来操作Mongodb。

1.小试牛刀

1.1.导入依赖

在 Java 程序中如果要使用 MongoDB,你需要确保已经安装了 Java 环境及 MongoDB JDBC 驱动,创建一个普通java项目,导入如下依赖

<dependencies>
    <dependency>
        <groupId>org.mongodb</groupId>
        <artifactId>mongo-java-driver</artifactId>
        <version>3.12.10</version>
    </dependency>
</dependencies>

1.2.连接MongDB

不使用账号连接:mongodb://localhost:27017 , 使用账号连接 mongodb://账号:密码@localhost:27017/

//1.创建客户端 : mongodb://用户名:密码@127.0.0.1:27017
 //如果没有账号:mongodb://127.0.0.1:27017
com.mongodb.client.MongoClient mongoClient = 
          MongoClients.create("mongodb://testuser:testuser@127.0.0.1:27017");

1.3.查询文档

通过客户端链接数据库,然后查询文档

//2.链接数据库tempdb
MongoDatabase userDB = mongoClient.getDatabase("tempdb");

//3.获取集合 user
FindIterable<Document> documentFindIterable = userDB.getCollection("user").find();

//4.拿到文档迭代器
MongoCursor<Document> iterator = documentFindIterable.iterator();
//5.遍历文档
while(iterator.hasNext()){
   
    System.out.println(iterator.next());
}

2.MongDB的CRUD

2.1.数据库CRUD

通过listDatabases查询所有数据库

//列出所有数据库
ListDatabasesIterable<Document> listDatabasesIterable = mongoClient.listDatabases();
MongoCursor<Document> iterator1 = listDatabasesIterable.iterator();
while(iterator1.hasNext()){
   
    System.out.println(iterator1.next());
}

通过 getDatabase 获取指定数据库

MongoDatabase empdb = mongoClient.getDatabase("empdb");
System.out.println(empdb.getName());

drop删除数据库

MongoDatabase empdb = mongoClient.getDatabase("empdb");
empdb.drop();

创建数据库 ,直接使用 mongoClient.getDatabase("db") ,当添加数据的时候会自动创建数据库

MongoDatabase testdb = mongoClient.getDatabase("testdb");
testdb.createCollection("user");

2.2.集合CRUD

查看集合

MongoCursor<Document> iterator2 = userDB.listCollections().iterator();
while (iterator2.hasNext()){
   
    System.out.println(iterator2.next());
}

获取某个集合

MongoCollection<Document> user = userDB.getCollection("集合名");

添加集合

userDB.createCollection("user");

//集合名,固定大小 , 最大文档数 ,最大字节数
userDB.createCollection("user", new CreateCollectionOptions().capped(true).maxDocuments(1000).sizeInBytes(1024*1024*1024));

//========================================================================================================
//验证规则,添加的文档中必须出现username和 age字段
ValidationOptions validationOptions = new ValidationOptions().validator(Filters.or(Filters.exists("username"),Filters.exists("age")));

userDB.createCollection("user",
                        //集合名,固定大小 , 最大文档数 ,最大字节数
                        new CreateCollectionOptions().capped(true).maxDocuments(1000).sizeInBytes(1024*1024*1024)
                        //添加的文档必须满足的验证规则
                        .validationOptions(validationOptions)
                       );

删除集合

//拿到集合 
MongoCollection<Document> user = userDB.getCollection("user");

//删除集合
 user.drop();

2.3.文档CRUD

创建文档

//创建集合
userDB.createCollection("tempcol");
//拿到集合
MongoCollection<Document> tempcol = userDB.getCollection("tempcol");
//创建文档
Document doc = new Document();
        doc.append("_id",1);
        doc.append("username","zs");
        doc.append("age",18).append("info",new Document("x","22").append("y","33"));
//添加文档
tempcol.insertOne(doc);

获取文档

//构建查询的内容
Document bson = new Document();
bson.put("_id",1);
//拿到集合,执行find
FindIterable<Document> documentFindIterable1 = userDB.getCollection("tempcol").find(bson);
//遍历结果
MongoCursor<Document> iterator3 = documentFindIterable1.iterator();
while(iterator3.hasNext()){
   
    System.out.println(iterator3.next());
}

//组装条件
MongoCollection<Document> tempcol = userDB.getCollection("tempcol");

Bson filter = Filters.and(Filters.eq("sex", 1), Filters.gte("age", 18));
FindIterable<Document> documentFindIterable = tempcol.find(filter);


//获取文档数量
userDB.getCollection("tempcol").countDocuments();

删除文档

//构建条件文档
Bson filter = Filters.eq("_id", 1);

//执行文档删除
DeleteResult result = userDB.getCollection("tempcol").deleteOne(bson);
System.out.println(result);


//删除符合条件的第一个文档
userDB.getCollection("tempcol").deleteOne(Filters.eq("likes", 200));  
//删除符合条件的所有文档
userDB.getCollection("tempcol").deleteMany (Filters.eq("likes", 200));

修改文档

//过滤条件,_id = 1
Bson filter = Filters.eq("_id", 1);
//把 age 设置为 100
Document update = new Document("$set",new Document("age",100));
//执行修改
UpdateResult updateResult = userDB.getCollection("tempcol").updateOne(filter, update);
System.out.println(updateResult);
相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。 &nbsp; 相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
相关文章
|
16小时前
|
Java Android开发
java利用xml-rpc协议操作wordpress博客
java利用xml-rpc协议操作wordpress博客
12 1
|
16小时前
|
监控 Java
Java一分钟之-NIO:非阻塞IO操作
【5月更文挑战第14天】Java的NIO(New IO)解决了传统BIO在高并发下的低效问题,通过非阻塞方式提高性能。NIO涉及复杂的选择器和缓冲区管理,易出现线程、内存和中断处理的误区。要避免这些问题,可以使用如Netty的NIO库,谨慎设计并发策略,并建立标准异常处理。示例展示了简单NIO服务器,接收连接并发送欢迎消息。理解NIO工作原理和最佳实践,有助于构建高效网络应用。
8 2
|
16小时前
|
安全 Java 数据安全/隐私保护
Java一分钟之-Java反射机制:动态操作类与对象
【5月更文挑战第12天】本文介绍了Java反射机制的基本用法,包括获取Class对象、创建对象、访问字段和调用方法。同时,讨论了常见的问题和易错点,如忽略访问权限检查、未捕获异常以及性能损耗,并提供了相应的避免策略。理解反射的工作原理和合理使用有助于提升代码灵活性,但需注意其带来的安全风险和性能影响。
19 4
|
16小时前
|
存储 NoSQL MongoDB
Mongodb 入门
Mongodb 入门
10 0
|
16小时前
|
SQL Java 关系型数据库
零基础轻松入门Java数据库连接(JDBC)
零基础轻松入门Java数据库连接(JDBC)
11 0
|
16小时前
|
存储 安全 算法
Java一分钟之-Java集合框架入门:List接口与ArrayList
【5月更文挑战第10天】本文介绍了Java集合框架中的`List`接口和`ArrayList`实现类。`List`是有序集合,支持元素重复并能按索引访问。核心方法包括添加、删除、获取和设置元素。`ArrayList`基于动态数组,提供高效随机访问和自动扩容,但非线程安全。文章讨论了三个常见问题:索引越界、遍历时修改集合和并发修改,并给出避免策略。通过示例代码展示了基本操作和安全遍历删除。理解并正确使用`List`和`ArrayList`能提升程序效率和稳定性。
7 0
|
16小时前
|
Java API
Java操作elasticsearch
Java操作elasticsearch
8 0
|
16小时前
|
NoSQL Java Redis
在Java中操作Redis
在Java中操作Redis
8 0
|
16小时前
|
SQL Java 关系型数据库
【JAVA基础篇教学】第十六篇:Java连接和操作MySQL数据库
【JAVA基础篇教学】第十六篇:Java连接和操作MySQL数据库
|
16小时前
|
Oracle 关系型数据库 Java
java操作多数据源将oracle数据同步达梦数据库
java操作多数据源将oracle数据同步达梦数据库