摘要:也可以修改查到的所有数据,如下罗贯中三国演义删可以删除查到的一条数据,如下罗贯中也可以删除查到的所有数据罗贯中里边还有其他的查询条件,都是见名知意,不赘述。
之前我们介绍的MongoDB的操作都是在shell命令中写的,在项目开发时我们当然都是用程序去操作MongoDB的,本文我们来看看如何用Java代码操作MongoDB。
本文是MongoDB系列的第十九篇文章,了解前面的文章有助于更好的理解本文:
1.Linux上安装MongoDB
2.MongoDB基本操作
3.MongoDB数据类型
4.MongoDB文档更新操作
5.MongoDB文档查询操作(一)
6.MongoDB文档查询操作(二)
7.MongoDB文档查询操作(三)
8.MongoDB查看执行计划
9.初识MongoDB中的索引
10.MongoDB中各种类型的索引
11.MongoDB固定集合
12.MongoDB管道操作符(一)
13.MongoDB管道操作符(二)
14.MongoDB中MapReduce使用
15.MongoDB副本集搭建
16.MongoDB副本集配置
17.MongoDB副本集其他细节
18.初识MongoDB分片
首先我们需要驱动,MongoDB的Java驱动我们可以直接在Maven中央仓库去下载,也可以创建Maven工程添加如下依赖:
org.mongodb mongodb-driver 3.5.0
建议通过Maven来添加依赖,如果自己下载jar,需要下载如下三个jar:
1.org.mongodb:bson:jar:3.5.0
2.org.mongodb:mongodb-driver-core:jar:3.5.0
3.org.mongodb:mongodb-driver:jar:3.5.0
另外,在使用Java操作MongoDB之前,记得启动MongoDB哦~
获取集合所有准备工作完成之后,我们首先需要一个MongoClient,如下:
MongoClient client = new MongoClient("192.168.248.136", 27017);
然后通过如下方式获取一个数据库,如果要获取的数据库本身就存在,直接获取到,不存在MongoDB会自动创建:
MongoDatabase sang = client.getDatabase("sang");
然后通过如下方式获取一个名为c1的集合,这个集合存在的话就直接获取到,不存在的话MongoDB会自动创建出来,如下:
MongoCollectionc = sang.getCollection("c1");
有了集合之后,我们就可以向集合中插入数据了。
增和在shell中的操作一样,我们可以一条一条的添加数据,也可以批量添加,添加单条数据操作如下:
Document d1 = new Document(); d1.append("name", "三国演义").append("author", "罗贯中"); c.insertOne(d1);
添加多条数据的操作如下:
List改collections = new ArrayList (); Document d1 = new Document(); d1.append("name", "三国演义").append("author", "罗贯中"); collections.add(d1); Document d2 = new Document(); d2.append("name", "红楼梦").append("author", "曹雪芹"); collections.add(d2); c.insertMany(collections);
可以修改查到的第一条数据,操作如下:
c.updateOne(Filters.eq("author", "罗贯中"), new Document("$set", new Document("name", "三国演义123")));
上例中小伙伴们也看到了修改器要如何使用,不管是$set还是$inc,用法都一致,我这里不再一个一个演示。也可以修改查到的所有数据,如下:
c.updateMany(Filters.eq("author", "罗贯中"), new Document("$set", new Document("name", "三国演义456")));删
可以删除查到的一条数据,如下:
c.deleteOne(Filters.eq("author", "罗贯中"));
也可以删除查到的所有数据:
c.deleteMany(Filters.eq("author", "罗贯中"));
Filters里边还有其他的查询条件,都是见名知意,不赘述。
查可以直接查询所有文档:
FindIterabledocuments = c.find(); MongoCursor iterator = documents.iterator(); while (iterator.hasNext()) { System.out.println(iterator.next()); }
也可以按照条件查询:
FindIterabledocuments = c.find(Filters.eq("author", "罗贯中")); MongoCursor iterator = documents.iterator(); while (iterator.hasNext()) { System.out.println(iterator.next()); }
其他的方法基本都是见名知意,这里不再赘述。
验证问题上面我们演示的获取一个集合是不需要登录MongoDB数据库的,如果需要登录,我们获取集合的方式改为下面这种:
ServerAddress serverAddress = new ServerAddress("192.168.248.128", 27017); ListcredentialsList = new ArrayList (); MongoCredential mc = MongoCredential.createScramSha1Credential("readuser","sang","123".toCharArray()); credentialsList.add(mc); MongoClient client = new MongoClient(serverAddress,credentialsList); MongoDatabase sang = client.getDatabase("sang"); c = sang.getCollection("c1");
MongoCredential是一个凭证,第一个参数为用户名,第二个参数是要在哪个数据库中验证,第三个参数是密码的char数组,然后将登录地址封装成一个ServerAddress,最后将两个参数都传入MongoClient中实现登录功能。
其他配置在连接数据库的时候也可以设置连接超时等信息,在MongoClientOptions中设置即可,设置方式如下:
ServerAddress serverAddress = new ServerAddress("192.168.248.128", 27017); ListcredentialsList = new ArrayList (); MongoCredential mc = MongoCredential.createScramSha1Credential("rwuser","sang","123".toCharArray()); credentialsList.add(mc); MongoClientOptions options = MongoClientOptions.builder() //设置连接超时时间为10s .connectTimeout(1000*10) //设置最长等待时间为10s .maxWaitTime(1000*10) .build(); MongoClient client = new MongoClient(serverAddress,credentialsList,options); MongoDatabase sang = client.getDatabase("sang"); c = sang.getCollection("c1");
好了,Java操作MongoDB我们就先说到这里,小伙伴们有问题欢迎留言讨论。
参考资料:
1.《MongoDB权威指南第2版》
更多资料请关注公众号:
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/19158.html
摘要:是一个轻量级框架,可以完成基于的应用程序的大部分配置工作。本文介绍如何使用操作,通过代码在里插入数据。首先按照这个教程的第一篇文章的介绍,在本地搭建好的环境最简单的入门教程之一环境搭建。 Spring Boot 是一个轻量级框架,可以完成基于 Spring 的应用程序的大部分配置工作。Spring Boot的目的是提供一组工具,以便快速构建容易配置的Spring应用程序,省去大量传统S...
摘要:原文保持更新及修正基于的客户端配置选项,其它驱动大同小异。连接池中连接的最大使用寿命毫秒。设置该选项后,客户端将进行以下行为以副本集模式连接,并根据给定的服务器发现副本集的所有成员。该选项可以和配合使用。编解码器用于对进行编码和解码。 原文保持更新及BUG修正:http://kweny.io/mongodb-clien... 基于 MongoDB Java Driver 3.8.1 ...
摘要:双刃剑的学习和避坑是一把双刃剑,它对数据结构的要求并不高。第二某些银行显示的金额不是实时的。第三步创建封装类的管理类,针对不同的实体类,需要配置不同的。 双刃剑MongoDB的学习和避坑 MongoDB 是一把双刃剑,它对数据结构的要求并不高。数据通过key-value的形式存储,而value的值可以是字符串,也可以是文档。所以我们在使用的过程中非常方便。正是这种方便给我们埋下了一颗颗...
阅读 634·2021-11-24 09:39
阅读 2959·2021-11-23 10:06
阅读 964·2021-10-08 10:05
阅读 736·2019-08-30 10:49
阅读 1686·2019-08-29 14:08
阅读 1291·2019-08-29 12:48
阅读 3305·2019-08-26 14:04
阅读 3592·2019-08-26 13:50