MongoDB Java Driver
本文使用 Java 来描述对 Mongodb 的相关操作,数据库版本是 3.2.8,驱动版本为 3.2.2。
本文将讨论
- 如何连接MongoDB
- 文档的 CURD 操作
- 文档的上传和下载
1. 连接到MongoDB
首先保证 mongodb 启动了身份验证功能(不启动直接使用IP,Port连接即可)。连接目标可分为三种:单机,集群和副本集。
1.1 连接单机和集群
站在代码的角度,单机和集群的区别就是端口号不同,假设服务器地址和端口号为:192.168.0.8和27017,则连接代码如下:
String user = "admin"; String pwd = "111111"; String authDb = "admin"; String host = "192.168.0.8"; int port = 27017; // 1. 直接连接 MongoCredential credential = MongoCredential.createCredential(user, authDb, pwd.toCharArray()); MongoClient mongoClient = new MongoClient(new ServerAddress(host , port), Arrays.asList(credential)); // 2. 使用连接字符串连接 // mongodb://user:pwd@host:port/?authSource=db String conString = "mongodb://{0}:{1}@{2}:{3}/?authSource={4}"; MongoClientURI uri = new MongoClientURI(MessageFormat.format(conString, user, pwd, host, port+"", authDb)); //注意port为字符串 MongoClient mongoClient = new MongoClient(uri);
1.2 连接副本集
// 1. 直接连接 MongoClient mongoCli1ent = new MongoClient( Arrays.asList(new ServerAddress("localhost", 27017), new ServerAddress("localhost", 27018)), Arrays.asList(MongoCredential.createCredential(user, authDb, pwd.toCharArray()))); // 2. 使用连接字符串 // mongodb://user:pwd@host:port, host:port/?authSource=db&replicaSet=rs&slaveOk=true String conStr = "mongodb://{0}:{1}@{2}:{3},{4}:{5}/?authSource={6}&replicaSet={7}&slaveOk=true"; MongoClientURI uri=new MongoClientURI(MessageFormat.format(conStr,"admin","111","host1","27017","host2","27018","admin","rs0")); MongoClient mongoClient = new MongoClient(uri);
1.3 关于连接相关的参数
不管是使用字符串连接,还是直接连接都可以附带一些参数,直接连接时用 MongoClientOptions 类的builder()构造,字符串直接使用 & 拼接在后面就行。常用的参数如下:
replicaSet=name | 副本集名称 | ssl=true|false | 是否使用ssl |
connectTimeoutMS=ms | 连接超时时间 | socketTimeoutMS=ms | socket超时时间 |
maxPoolSize=n | 连接池大小 | safe=true|false | 驱动是否发送getLastError |
journal=true|false | 是否等待将日志刷到磁盘 | ||
authMechanism= | 身份验证方式 | 验证方式有SCRAM-SHA-1 | MONGODB-X509,MONGO-CR,etc |
authSource=string | 验证数据库,默认admin | 采用指定数据库的验证方式 | 3.0之后,默认验证方式为 SCRAM-SHA-1. |
更多详细的参数请见:MongoClientURI
2. 文档的 CURD 操作
在进行 CURD 操作时,有几个常用的辅助静态类:Filters, Sorts, Projections,Updates,详细用法请查看:Builders
(1)文档的插入
// 获取待插入集合 mycol MongoDatabase mydb = mongoClient.getDatabase("myDb"); MongoCollection<Document> mycol = mydb.getCollection("myCol"); // 生成一个文档 Document doc = new Document(); doc.put("name", "cyhe"); doc.put("blog", "http://www.cnblogs.com/cyhe/"); // 也可以使用链式风格构建 new Document("id",1).append("name", "cyhe");// ... etc // 也可以直接将 JSON 转成 BSON doc = Document.parse("{\"name\":\"cyhe\",\"blog\":\"http://www.cnblogs.com/cyhe/\"}"); // 插入 mycol.insertOne(doc); // 批量插入 mycol.insertMany(new ArrayList<Document>());
(2)文档的查找
// 查询集合所有文档 List<Document> docs = mycol.find().into(new ArrayList<Document>()); // 直接导入 import static com.mongodb.client.model.Filters.*; 就可以直接使用 and eq 等静态方法 // 查询 age = 20 的文档 Document doc = mycol.find(Filters.eq("age", 20)).first(); // 查询 10<age<20 的文档 返回一个游标 MongoCursor<Document> cur=mycol.find(Filters.and(Filters.gt("age", 10), Filters.lt("age", 20))).iterator();
(3)文档的更新和删除
// 查找并删除名称为 cyhe 的文档 mycol.findOneAndDelete(Filters.eq("name", "cyhe")); // 查找并重命名 mycol.findOneAndUpdate(Filters.eq("name", "cyhe"), Updates.set("name", "wqq")); // 小于10的都加1 mycol.updateMany(Filters.lt("size", 10), Updates.inc("size", 1)); // 删除 age 大于 110 的文档 mycol.deleteOne(Filters.gt("age", "110"));
3. 文档的上传和下载
在Mongodb中,普通文档最大为16M,对于图片,附件来说就显得比较小了,mongodb的处理方式就是使用 GridFS 分块存储。
// GridFS 默认的名字为 fs,使用默认名称连接 GridFSBucket gridFSBucket = GridFSBuckets.create(mydb); // 使用指定名称连接 GridFSBucket gridFSBucket1 = GridFSBuckets.create(mydb, "imags"); // 上传文件 // ============================================================================================== InputStream streamToUploadFrom = new FileInputStream(new File("/tmp/mongodb-tutorial.pdf")); // 自定义参数 GridFSUploadOptions options = new GridFSUploadOptions() .chunkSizeBytes(1024) .metadata(new Document("type", "presentation")); ObjectId fileId = gridFSBucket.uploadFromStream("mongodb-tutorial", streamToUploadFrom, options); // =============================================================================================== // 或者使用 GridFSUploadStream byte[] data = "Data to upload into GridFS".getBytes(StandardCharsets.UTF_8); GridFSUploadStream uploadStream = gridFSBucket.openUploadStream("sampleData", options); uploadStream.write(data); uploadStream.close(); System.out.println("The fileId of the uploaded file is: " + uploadStream.getFileId().toHexString()); // =============================================================================================== // 下载文件 // =============================================================================================== // 根据生成的 ObjectId 下载 FileOutputStream streamToDownloadTo = new FileOutputStream("/tmp/mongodb-tutorial.pdf"); gridFSBucket.downloadToStream(fileId, streamToDownloadTo); streamToDownloadTo.close(); System.out.println(streamToDownloadTo.toString()); // =============================================================================================== // 根据文件名称下载 FileOutputStream streamToDownloadTo = new FileOutputStream("/tmp/mongodb-tutorial.pdf"); GridFSDownloadByNameOptions downloadOptions = new GridFSDownloadByNameOptions().revision(0); gridFSBucket.downloadToStreamByName("mongodb-tutorial", streamToDownloadTo, downloadOptions); streamToDownloadTo.close(); // =============================================================================================== // 使用 GridFSDownloadStream 根据 ObjectId 下载 GridFSDownloadStream downloadStream = gridFSBucket.openDownloadStream(fileId); int fileLength = (int) downloadStream.getGridFSFile().getLength(); byte[] bytesToWriteTo = new byte[fileLength]; downloadStream.read(bytesToWriteTo); downloadStream.close(); System.out.println(new String(bytesToWriteTo, StandardCharsets.UTF_8)); // =============================================================================================== // 使用 GridFSDownloadStream 根据 名称 下载 GridFSDownloadStream downloadStream = gridFSBucket.openDownloadStreamByName("sampleData"); int fileLength = (int) downloadStream.getGridFSFile().getLength(); byte[] bytesToWriteTo = new byte[fileLength]; downloadStream.read(bytesToWriteTo); downloadStream.close(); System.out.println(new String(bytesToWriteTo, StandardCharsets.UTF_8));
本文只是 Mongodb 操作的冰山一角,更多的用法,会在以后的实战中不断更新完善。更多用法和 API 介绍,详见 MongoDB-Java-3.2
MongoDB Java Driver的更多相关文章
- MongoDB Java Driver操作指南
MongoDB为Java提供了非常丰富的API操作,相比关系型数据库,这种NoSQL本身的数据也有点面向对象的意思,所以对于Java来说,Mongo的数据结构更加友好. MongoDB在今年做了一次重 ...
- Mongodb Java Driver 参数配置解析
要正确使用Mongodb Java Driver,MongoClientOptions参数配置对数据库访问的并发性能影响极大. connectionsPerHost:与目标数据库能够建立的最大conn ...
- MongoDB Java Driver 3.4操作
导入jar包 <dependency> <groupId>org.mongodb</groupId> <artifactId>mongo-java-dr ...
- BuguMongo是一个MongoDB Java开发框架,集成了DAO、Query、Lucene、GridFS等功能
http://code.google.com/p/bugumongo/ 简介 BuguMongo是一个MongoDB Java开发框架,它的主要功能包括: 基于注解的对象-文档映射(Object-Do ...
- 数据库.MongoDB.Java样例
1.先在MongoDB官网下载Java驱动包 MongoDB Java Driver: http://mongodb.github.io/mongo-java-driver/ JAR包下载列表 htt ...
- 给java mongodb 官方driver 增加bean 操作
mongodb官方的java driver不支持直接插入java bean,只能使用DbObject的Key,Value形式进行insert,update,(c# mongodb官方driver类 ...
- Date, TimeZone, MongoDB, java中date的时区问题
打印new Date(),Fri Aug 12 13:37:51 CST 2016. 显示Asia/Shanghai的时区,但是date toString 的时区简写却是CST.更坑爹的是,Googl ...
- [译] MongoDB Java异步驱动快速指南
导读 mongodb-java-driver是mongodb的Java驱动项目. 本文是对MongoDB-java-driver官方文档 MongoDB Async Driver Quick Tour ...
- MongoDB C Driver使用教程
MongoDB C Driver使用教程 转载请注明出处http://www.cnblogs.com/oloroso/ 本指南提供简介 MongoDB C 驱动程序. 在 C API 的详细信息,请参 ...
随机推荐
- 手机Fildder抓包_监控应用请求
Fiddler是一个http调试代理,它能 够记录所有的你电脑和互联网之间的http通讯,Fiddler 可以也可以让你检查所有的http通讯,设置断点,以及Fiddle 所有的“进出”的数据(指co ...
- Java总结篇系列:Java多线程(二)
本文承接上一篇文章<Java总结篇系列:Java多线程(一)>. 四.Java多线程的阻塞状态与线程控制 上文已经提到Java阻塞的几种具体类型.下面分别看下引起Java线程阻塞的主要方法 ...
- 【Java每日一题】20161124
package Nov2016; public class Ques1124 { public static void main(String[] args) { Parent p = new Sub ...
- Codeforces Round #369 (Div. 2)---C - Coloring Trees (很妙的DP题)
题目链接 http://codeforces.com/contest/711/problem/C Description ZS the Coder and Chris the Baboon has a ...
- ahjesus code simith 存储过程模板
<%------------------------------------------------------------------------------------------ * Au ...
- win7系统旗舰版path
%SystemRoot%\system32;%SystemRoot%;%SystemRoot%\System32\Wbem;%SYSTEMROOT%\System32\WindowsPowerShel ...
- 相识不易,要懂珍惜----------Spring Mvc
一.Spring Mvc简介 Spring Mvc也叫Spring Web Mvc,属于表现层额框架.Spring Mvc是Spring框架的一部分,是在Spring3.0后发布的. 二.Spring ...
- php 相关模块备忘
在安装php的时候,不管是编译安装: ./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc -- ...
- Exif.js 读取图像的元数据
Exif.js 提供了 JavaScript 读取图像的原始数据的功能扩展,例如:拍照方向.相机设备型号.拍摄时间.ISO 感光度.GPS 地理位置等数据. 注意事项: EXIF 数据主要来自拍摄的照 ...
- [实现]Javascript代码的另一种压缩与加密方法——代码图片转换
代码=图片 图片=代码 JS代码对于喜欢F12的同志来说,连个遮羞布都没有... 虽然把代码变成图片也仅仅只是增加一层纱布而已...但这方法还是挺好玩的,而且代码也被压缩了一点. 第一次看到[图片=代 ...