对Collection的操作

 import java.util.ArrayList;
import java.util.Iterator;
import java.util.List; import org.bson.Document; import com.mongodb.Block;
import com.mongodb.MongoClient;
import com.mongodb.MongoClientURI;
import com.mongodb.MongoCredential;
import com.mongodb.ServerAddress;
import com.mongodb.client.FindIterable;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoCursor;
import com.mongodb.client.MongoDatabase;
import com.mongodb.client.result.DeleteResult;
import com.mongodb.client.result.UpdateResult;
import com.mongodb.client.model.BulkWriteOptions;
import com.mongodb.client.model.DeleteOneModel;
import com.mongodb.client.model.Filters;
import com.mongodb.client.model.InsertOneModel;
import com.mongodb.client.model.Projections;
import com.mongodb.client.model.ReplaceOneModel;
import com.mongodb.client.model.Sorts;
import com.mongodb.client.model.UpdateOneModel;
import com.mongodb.client.model.WriteModel; import static com.mongodb.client.model.Filters.gt; /***/
import static com.mongodb.client.model.Filters.eq;
import static com.mongodb.client.model.Filters.and;
import static com.mongodb.client.model.Filters.lt; public class MongoDBJDBC { @SuppressWarnings("resource")
public static void main(String[] args) {
try {
/** 直接登录 */
// To directly connect to a single MongoDB server.
// (this will not auto-discover the primary even if it's a member of a replica set)
/*
MongoClient mongoClient = new MongoClient("192.168.253.10", 27017);
MongoDatabase mongoDatabase = mongoClient.getDatabase("dsp");
System.out.println("Connect to database successfully!");
*/ /** 使用URI连接信息连接 */
/*
MongoClientURI connectionString = new MongoClientURI("mongodb://192.168.253.10:27017,192.168.253.20:27018,192.168.253.30:27019");
MongoClient mongoClient = new MongoClient(connectionString);
*/ /** Replica Set 认证登录 */
// to connect to a replica set, with auto-discovery of the primary, supply a seed list of members
// 数据库URI(两个参数分别为:服务器地址、端口)
ServerAddress serverAddress = new ServerAddress("192.168.253.10", 27017);
List<ServerAddress> addressList = new ArrayList<ServerAddress>();
addressList.add(serverAddress);
// 认证信息(三个参数分别为:用户名、数据库名称、密码)
MongoCredential credential = MongoCredential.createScramSha1Credential("dsp", "dsp", "shi".toCharArray());
List<MongoCredential> credentialList = new ArrayList<MongoCredential>();
credentialList.add(credential);
// 根据URI和认证信息获取数据库连接
MongoClient mongoClient = new MongoClient(addressList, credentialList); /** 切换数据库 */
MongoDatabase mongoDatabase = mongoClient.getDatabase("dsp");
/** 切换到需要操作的集合 */
MongoCollection collection = mongoDatabase.getCollection("col"); /** 插入文档 */
// 创建文档 org.bson.Document对象,参数为K:V格式
// 创建文档集合List<Document>
// 将文档集合插入数据库集合中collection.insertMany(List<Document>),插入单个文档可以用collection.insertOne(Document)
/*
List<Document> docList = new ArrayList<Document>();
for (int idx = 0; idx < 10; ++idx) {
Document doc = new Document("title", "MongoDB" + idx).
append("desc", "数据库" + idx).
append("likes", 100 + idx * 10).
append("by", "dsp" + idx);
docList.add(doc);
}
collection.insertMany(docList);
*/ /** 更新文档 */
/*
UpdateResult updateResult = collection.updateMany(and(gt("likes", 90), lt("likes", 110)), new Document("$set", new Document("likes", 30)));
updateResult.getMatchedCount();
updateResult.getUpsertedId();
updateResult.getModifiedCount();
*/ /** 删除文档 */
/*
DeleteResult deleteResult = collection.deleteMany(Filters.eq("likes", 30));
System.out.println("本次删除 " + deleteResult.getDeletedCount() + " 条记录!");
*/ /** 检索文档 */
/*
FindIterable<Document> findIterable = collection.find();
MongoCursor<Document> mongoCursor = findIterable.iterator();
try {
while (mongoCursor.hasNext()) {
System.out.println(mongoCursor.next().toJson());
}
} finally {
mongoCursor.close();
}
*/ // 查询过滤器
/*
Document myDoc = (Document) collection.find(eq("likes", 10)).first();
System.out.println(myDoc.toJson());
*/ /** 使用范围查询获取一个较大的子集 */
Block<Document> printBlock = new Block<Document>() {
@Override
public void apply(Document doc) {
System.out.println(doc.toJson());
}
};
// 过滤 likes > 10
// collection.find(gt("likes", 10)).forEach(printBlock);
// 过滤 10 <= likes <= 100
// collection.find(and(Filters.gte("likes", 10), Filters.lte("likes", 100))).forEach(printBlock); /** 排序 */
// collection.find(Filters.exists("likes")).sort(Sorts.descending("likes")).limit(2).forEach(printBlock); /** Projection */
// Document myDoc = (Document) collection.find().projection(Projections.excludeId()).first();
// System.out.println(myDoc.toJson()); /** ordered bulk writes */
List<WriteModel<Document>> writes = new ArrayList<WriteModel<Document>>();
writes.add(new InsertOneModel<Document>(new Document("_id", 13)));
writes.add(new InsertOneModel<Document>(new Document("_id", 14)));
writes.add(new InsertOneModel<Document>(new Document("_id", 15)));
writes.add(new UpdateOneModel<Document>(new Document("_id", 10), new Document("$set", new Document("x", 101010))));
writes.add(new DeleteOneModel<Document>(new Document("_id", 11)));
writes.add(new ReplaceOneModel<Document>(new Document("_id", 12), new Document("_id", 12).append("x", 121212)));
// bulkWrite默认BulkWriteOptions
// collection.bulkWrite(writes);
// collection.find().forEach(printBlock);
//
// collection.bulkWrite(writes, new BulkWriteOptions().ordered(false));
// collection.find().forEach(printBlock); /** drop集合 */
// collection.drop(); /** drop数据库 */
// mongoDatabase.drop();
} catch (Exception e) {
System.err.println(e.getClass().getName() + " : " + e.getMessage());
} finally {
// 防止意外,关闭数据库连接
// mongoClient.close();
}
} }

参考:

https://github.com/mongodb/mongo-java-driver/blob/3.0.x/driver/src/examples/tour/QuickTour.java

http://mongodb.github.io/mongo-java-driver/3.0/driver/getting-started/quick-tour/

:)

MongoDB 3.X JAVA基本操作的更多相关文章

  1. 4.0.3的mongodb 安装和java使用

    一 整合 由于本人的码云太多太乱了,于是决定一个一个的整合到一个springboot项目里面. 附上自己的github项目地址 https://github.com/247292980/spring- ...

  2. hbase的Java基本操作

    hbase的Java基本操作 建表,建列簇操作 private static Connection connection; private static Admin admin; public sta ...

  3. MongoDB的ObjectId和基本操作增删改查(3)

    ObjectId 基本操作增删改查 增: insert 介绍: mongodb存储的是文档,. 文档是json格式的对象. 语法: db.collectionName.insert(document) ...

  4. MongoDB的安装和基本操作

    一.使用前的准备(windows下的安装)  1.下载 目前MongoDB的官网不知道问什么不能进行下载了,但是可以在MongoDB中文论坛进行下载, 地址如下:http://www.mongoing ...

  5. 【MongoDB数据库】Java MongoDB CRUD Example

    上一页告诉我们MongoDB 命令入门初探,本篇blog将基于上一篇blog所建立的数据库和表完毕一个简单的Java MongoDB CRUD Example.利用Java连接MongoDB数据库,并 ...

  6. MongoDB文档的基本操作

    1. MongoDB的安装方法 (1)下载MongoDB 相应的版本: (2)设置数据文件和日志文件的存放目录: (3)启动MongoDB服务: (4)将MongoDB作为服务启动. 2. Mongo ...

  7. MongoDB分页的Java实现和分页需求的思考

    前言 传统关系数据库中都提供了基于row number的分页功能,切换MongoDB后,想要实现分页,则需要修改一下思路. 传统分页思路 假设一页大小为10条.则 //page 1 1-10 //pa ...

  8. 学习MongoDB 七: MongoDB索引(索引基本操作)(一)

    一.简介 在MongoDB建立索引能提高查询效率,只需要扫描索引只存储的这个集合的一小部分,并只把这小部分加载到内存中,效率大大的提高,如果没有建立索引,在查询时,MongoDB必须执行全表扫描,在数 ...

  9. Java操作Mongodb 保存/读取java对象到/从mongodb

    从http://central.maven.org/maven2/org/mongodb/mongo-java-driver/选择一个版本进行下载,这里选择的是3.0.0版本,具体下载以下jar包: ...

随机推荐

  1. Tcpdump 的用法

    1.抓取回环网口的包:tcpdump -i lo 2.防止包截断:tcpdump -s0 3.以数字显示主机及端口:tcpdump -n 第一种是关于类型的关键字,主要包括host,net,port, ...

  2. Markdown语法学习(二)

    概述 宗旨 Markdown 的目标是实现「易读易写」. 可读性,无论如何,都是最重要的.一份使用 Markdown 格式撰写的文件应该可以直接以纯文本发布,并且看起来不会像是由许多标签或是格式指令所 ...

  3. crontab格式,命令

    http://www.blogjava.net/xiaomage234/archive/2007/12/26/170490.html crontab格式: 第1列分钟1-59 第2列小时1-23(0表 ...

  4. 浅析notifyDataSetChanged内部工作流程

    Reference: http://blog.csdn.net/hp910315/article/details/47174531 首先我们知道notifyDataSetChanged是Adater的 ...

  5. FastText算法原理解析

    1. 前言 自然语言处理(NLP)是机器学习,人工智能中的一个重要领域.文本表达是 NLP中的基础技术,文本分类则是 NLP 的重要应用.fasttext是facebook开源的一个词向量与文本分类工 ...

  6. 基于jQuery适合做图片类网站的特效

    分享一款基于jquery适合做图片类网站的特效.这是一款鼠标经过图片滑动弹出标题效果代码.效果图如下: 在线预览   源码下载 实现的代码. html代码: <div class="c ...

  7. 【转】jdbc:oracle:thin:@192.168.3.98:1521:orcl(详解)

    整理自互联网 一. jdbc:oracle:thin:@192.168.3.98:1521:orcljdbc:表示采用jdbc方式连接数据库oracle:表示连接的是oracle数据库thin:表示连 ...

  8. Xcode7.3 beta 新功能 https://developer.apple.com/go/?id=xcode-7.3-rn

    Xcode7.3 beta 新功能html, body {overflow-x: initial !important;}html { font-size: 14px; } body { margin ...

  9. sql优化方法学习和总结

    首先要问自己几个问题: 哪些类型的sql会散发出坏味道? sql优化的基本原理是什么,为什么有的sql快有的慢? sql优化和底层的存储引擎关系大么? 怎么看执行过程? 优化建议 1. 缓存查询,sq ...

  10. C语言 · 判断回文

    算法提高 判断回文   时间限制:1.0s   内存限制:512.0MB      编程判断一个字符串是否是回文,当字符串是回文时,输出字符串:yes!,否则输出字符串:no!.所谓回文即正向与反向的 ...