java连接mongoDB 并进行增删改查操作

java连接mongoDB 并进行增删改查操作

1、安装 MongoDB JDBC驱动程序

在java中使用mongoDB之前,首先需要拥有java连接mongoDB的第三方驱动包(jar包)

1)maven项目可通过在pom.xml中添加依赖

 
  1. <dependencies>

  2. <dependency>

  3. <groupId>org.mongodb</groupId>

  4. <artifactId>mongo-java-driver</artifactId>

  5. <version>3.0.4</version>

  6. </dependency>

  7. </dependencies>

2)非maven项目jar包下载地址:

       mongoDB jar包

2、连接数据库

将mongoDB JDBC驱动加入到项目之后,就可以对mongoDB进行操作了。

1)不通过认证连接mongoDB服务

 
  1. //连接到 mongodb 服务

  2. MongoClient mongoClient = new MongoClient("localhost", 27017);

这里的 "localhost" 表示连接的服务器地址,27017 为端口号。可以省略 端口号 不写,系统将默认端口号为 27017。如:

 
  1. //连接到 mongodb 服务,默认端口号为27017

  2. MongoClient mongoClient = new MongoClient("localhost");

也可以将 服务器地址 和 端口号 都省略,系统默认服务器地址为 "localhost",端口号为 27017。如:

 
  1. //连接到 mongodb 服务,默认连接到localhost服务器,端口号为27017

  2. MongoClient mongoClient = new MongoClient();

2)通过认证连接mongoDB服务

 
  1. List<ServerAddress> adds = new ArrayList<>();

  2. //ServerAddress()两个参数分别为 服务器地址 和 端口

  3. ServerAddress serverAddress = new ServerAddress("localhost", 27017);

  4. adds.add(serverAddress);

  5.  
  6. List<MongoCredential> credentials = new ArrayList<>();

  7. //MongoCredential.createScramSha1Credential()三个参数分别为 用户名 数据库名称 密码

  8. MongoCredential mongoCredential = MongoCredential.createScramSha1Credential("username", "databaseName", "password".toCharArray());

  9. credentials.add(mongoCredential);

  10.  
  11. //通过连接认证获取MongoDB连接

  12. MongoClient mongoClient = new MongoClient(adds, credentials);

ServerAddress()两个参数 "localhost" , 27017 分别为 服务器地址 和 端口。

MongoCredential.createScramSha1Credential()三个参数 "username", "databaseName", "password".toCharArray() 分别为 用户名 数据库名称 密码。

3)连接到数据库

 
  1. //连接到数据库

  2. MongoDatabase mongoDatabase = mongoClient.getDatabase("test");

这里的 "test" 表示数据库名,若指定的数据库不存在,mongoDB将会在你第一次插入文档时创建数据库。

4)封装成工具类

由于所有连接数据库操作都需要执行这两步操作,我们可以将这两步操作封装成工具类。

 
  1. import com.mongodb.MongoClient;

  2. import com.mongodb.client.MongoDatabase;

  3.  
  4. //mongodb 连接数据库工具类

  5. public class MongoDBUtil {

  6. //不通过认证获取连接数据库对象

  7. public static MongoDatabase getConnect(){

  8. //连接到 mongodb 服务

  9. MongoClient mongoClient = new MongoClient("localhost", 27017);

  10.  
  11. //连接到数据库

  12. MongoDatabase mongoDatabase = mongoClient.getDatabase("test");

  13.  
  14. //返回连接数据库对象

  15. return mongoDatabase;

  16. }

  17.  
  18. //需要密码认证方式连接

  19. public static MongoDatabase getConnect2(){

  20. List<ServerAddress> adds = new ArrayList<>();

  21. //ServerAddress()两个参数分别为 服务器地址 和 端口

  22. ServerAddress serverAddress = new ServerAddress("localhost", 27017);

  23. adds.add(serverAddress);

  24.  
  25. List<MongoCredential> credentials = new ArrayList<>();

  26. //MongoCredential.createScramSha1Credential()三个参数分别为 用户名 数据库名称 密码

  27. MongoCredential mongoCredential = MongoCredential.createScramSha1Credential("username", "databaseName", "password".toCharArray());

  28. credentials.add(mongoCredential);

  29.  
  30. //通过连接认证获取MongoDB连接

  31. MongoClient mongoClient = new MongoClient(adds, credentials);

  32.  
  33. //连接到数据库

  34. MongoDatabase mongoDatabase = mongoClient.getDatabase("test");

  35.  
  36. //返回连接数据库对象

  37. return mongoDatabase;

  38. }

  39. }

3、对数据库进行CRUD

mongoDB中的数据都是通过文档(对应于关系型数据库表中的一行)保存的,而文档又保存在集合(对应于关系型数据库的表)中。

1)获取集合

要对数据进行CRUD操作首先要获取到操作的集合。

 
  1. //获取集合

  2. MongoCollection<Document> collection = MongoDBUtil.getConnect().getCollection("user");

这里的 "user" 表示集合的名字,如果指定的集合不存在,mongoDB将会在你第一次插入文档时创建集合。

2)创建文档

要插入文档首先需要创建文档对象

 
  1. //创建文档

  2. Document document = new Document("name","张三")

  3. .append("sex", "男")

  4. .append("age", 18);

3)插入文档

插入一个文档,使用 MongoCollection 对象的 insertOne() 方法,该方法接收一个 Document 对象作为要插入的数据

 
  1. //插入一个文档

  2. @Test

  3. public void insertOneTest(){

  4. //获取数据库连接对象

  5. MongoDatabase mongoDatabase = MongoDBUtil.getConnect();

  6. //获取集合

  7. MongoCollection<Document> collection = mongoDatabase.getCollection("user");

  8. //要插入的数据

  9. Document document = new Document("name","张三")

  10. .append("sex", "男")

  11. .append("age", 18);

  12. //插入一个文档

  13. collection.insertOne(document);

  14. }

插入多个文档,使用 MongoCollection 对象的 insertMany() 方法,该方法接收一个 数据类型为 Document 的 List 对象作为要插入的数据

 
  1. //插入多个文档

  2. @Test

  3. public void insertManyTest(){

  4. //获取数据库连接对象

  5. MongoDatabase mongoDatabase = MongoDBUtil.getConnect();

  6. //获取集合

  7. MongoCollection<Document> collection = mongoDatabase.getCollection("user");

  8. //要插入的数据

  9. List<Document> list = new ArrayList<>();

  10. for(int i = 1; i <= 3; i++) {

  11. Document document = new Document("name", "张三")

  12. .append("sex", "男")

  13. .append("age", 18);

  14. list.add(document);

  15. }

  16. //插入多个文档

  17. collection.insertMany(list);

  18. }

4)删除文档

删除与筛选器匹配的单个文档,使用 MongoCollection 对象的 deleteOne() 方法,该方法接收一个数据类型为 Bson 的的对象作为过滤器筛选出需要删除的文档。然后删除第一个。为了便于创建过滤器对象,JDBC驱动程序提供了 Filters 类。

 
  1. //删除与筛选器匹配的单个文档

  2. @Test

  3. public void deleteOneTest(){

  4. //获取数据库连接对象

  5. MongoDatabase mongoDatabase = MongoDBUtil.getConnect();

  6. //获取集合

  7. MongoCollection<Document> collection = mongoDatabase.getCollection("user");

  8. //申明删除条件

  9. Bson filter = Filters.eq("age",18);

  10. //删除与筛选器匹配的单个文档

  11. collection.deleteOne(filter);

  12. }

删除与筛选器匹配的所有文档,使用 MongoCollection 对象的 deleteMany() 方法,该方法接收一个数据类型为 Bson 的的对象作为过滤器筛选出需要删除的文档。然后删除所有筛选出的文档。

 
  1. //删除与筛选器匹配的所有文档

  2. @Test

  3. public void deleteManyTest(){

  4. //获取数据库连接对象

  5. MongoDatabase mongoDatabase = MongoDBUtil.getConnect();

  6. //获取集合

  7. MongoCollection<Document> collection = mongoDatabase.getCollection("user");

  8. //申明删除条件

  9. Bson filter = Filters.eq("age",18);

  10. //删除与筛选器匹配的所有文档

  11. collection.deleteMany(filter);

  12. }

5)修改文档

修改单个文档,使用 MongoCollection 对象的 updateOne() 方法,该方法接收两个参数,第一个数据类型为 Bson 的过滤器筛选出需要修改的文档,第二个参数数据类型为 Bson 指定如何修改筛选出的文档。然后修改过滤器筛选出的第一个文档。

 
  1. //修改单个文档

  2. @Test

  3. public void updateOneTest(){

  4. //获取数据库连接对象

  5. MongoDatabase mongoDatabase = MongoDBUtil.getConnect();

  6. //获取集合

  7. MongoCollection<Document> collection = mongoDatabase.getCollection("user");

  8. //修改过滤器

  9. Bson filter = Filters.eq("name", "张三");

  10. //指定修改的更新文档

  11. Document document = new Document("$set", new Document("age", 100));

  12. //修改单个文档

  13. collection.updateOne(filter, document);

  14. }

修改多个文档,使用 MongoCollection 对象的 updateMany() 方法,该方法接收两个参数,第一个数据类型为 Bson 的过滤器筛选出需要修改的文档,第二个参数数据类型为 Bson 指定如何修改筛选出的文档。然后修改过滤器筛选出的所有文档。

 
  1. //修改多个文档

  2. @Test

  3. public void updateManyTest(){

  4. //获取数据库连接对象

  5. MongoDatabase mongoDatabase = MongoDBUtil.getConnect();

  6. //获取集合

  7. MongoCollection<Document> collection = mongoDatabase.getCollection("user");

  8. //修改过滤器

  9. Bson filter = Filters.eq("name", "张三");

  10. //指定修改的更新文档

  11. Document document = new Document("$set", new Document("age", 100));

  12. //修改多个文档

  13. collection.updateMany(filter, document);

  14. }

6)查询文档

使用 MongoCollection 对象的 find() 方法,该方法有多个重载方法,可以使用不带参数的 find() 方法查询集合中的所有文档,也可以通过传递一个 Bson 类型的 过滤器查询符合条件的文档。这几个重载方法均返回一个 FindIterable 类型的对象,可通过该对象遍历出查询到的所有文档。

查找集合中的所有文档

 
  1. //查找集合中的所有文档

  2. @Test

  3. public void findTest(){

  4. //获取数据库连接对象

  5. MongoDatabase mongoDatabase = MongoDBUtil.getConnect();

  6. //获取集合

  7. MongoCollection<Document> collection = mongoDatabase.getCollection("user");

  8. //查找集合中的所有文档

  9. FindIterable findIterable = collection.find();

  10. MongoCursor cursor = findIterable.iterator();

  11. while (cursor.hasNext()) {

  12. System.out.println(cursor.next());

  13. }

  14. }

指定查询过滤器查询

 
  1. //指定查询过滤器查询

  2. @Test

  3. public void FilterfindTest(){

  4. //获取数据库连接对象

  5. MongoDatabase mongoDatabase = MongoDBUtil.getConnect();

  6. //获取集合

  7. MongoCollection<Document> collection = mongoDatabase.getCollection("user");

  8. //指定查询过滤器

  9. Bson filter = Filters.eq("name", "张三");

  10. //指定查询过滤器查询

  11. FindIterable findIterable = collection.find(filter);

  12. MongoCursor cursor = findIterable.iterator();

  13. while (cursor.hasNext()) {

  14. System.out.println(cursor.next());

  15. }

  16. }

可通过 first() 方法取出查询到的第一个文档

 
  1. //取出查询到的第一个文档

  2. @Test

  3. public void findTest(){

  4. //获取数据库连接对象

  5. MongoDatabase mongoDatabase = MongoDBUtil.getConnect();

  6. //获取集合

  7. MongoCollection<Document> collection = mongoDatabase.getCollection("user");

  8. //查找集合中的所有文档

  9. FindIterable findIterable = collection.find();

  10. //取出查询到的第一个文档

  11. Document document = (Document) findIterable.first();

  12. //打印输出

  13. System.out.println(document);

  14. }

4、总结

到这里,java对mongoDB的一些基本操作就介绍完了。实现的步骤为:添加驱动==>连接到服务==>连接到数据库==>选择集合==>对集合进行CRUD操作。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值