MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。下面介绍的是用java操作MongoDB的一些常用写法。

  1.引用java操作MongoDB驱动包

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

  2.java操作MongoDB一些常用写法

public class MongoDBTest
{
//定义一个客户端
private MongoClient client = null; //定义一个MongoDB数据库
private MongoDatabase database = null; @Before
public void init()
{
//连接MongoDB客户端
client = new MongoClient("127.0.0.1", 27017);
//使用数据库mongoDataBase
database = client.getDatabase("mongoDataBase");
} /**
*
* @描述:向user集合中添加一条数据
*/
@Test
public void testInsertOne()
{
//获取user集合
MongoCollection<Document> collection = database.getCollection("user");
Document document = new Document();
document.append("userName", "jack");
document.append("age", 23);
document.append("sex", "男");
collection.insertOne(document);
} /**
*
* @描述:向user集合中添加多条数据
*/
@Test
public void testInsertMany()
{
//获取user集合
MongoCollection<Document> userCollection = database.getCollection("user");
//定义多个Document对象
Document document1 = new Document("userName", "lily");
document1.append("age", 24);
document1.append("sex", "男");
Document document2 = new Document("userName", "mary");
document2.append("age", 30);
document2.append("sex", "女");
Document document3 = new Document("userName", "小吴");
document3.append("age", 27);
document3.append("sex", "男");
userCollection.insertMany(Arrays.asList(document1, document2, document3));
} /**
*
* @描述:删除user集合中数据
*/
@Test
public void remove()
{
//获取user集合
MongoCollection<Document> userCollection = database.getCollection("user");
//执行删除的方法(删除age=23的所有人)
//构造删除条件
Bson delBson = Filters.eq("age", 23);
//一次性删除所有符合条件的数据(删除age=23的所有人)
userCollection.deleteMany(delBson);
} /**
*
* @描述:删除user集合中数据(带多个删除条件的)
*/
@Test
public void remove2()
{
//获取users集合
MongoCollection<Document> userCollection = database.getCollection("user");
//执行删除的方法(删除age>=20 并且 age<=30的所有人)
//构造删除条件(age>=20)
Bson delBson1 = Filters.gte("age", 20);
//构造删除条件(age<=30)
Bson delBson2 = Filters.lte("age", 30);
//合并删除条件
Bson delBson = Filters.and(delBson1, delBson2);
userCollection.deleteMany(delBson);
} /**
*
* @描述:查询出user集合中所有数据
*/
@Test
public void testGetAll2()
{
//获取user集合
MongoCollection<Document> userCollection = database.getCollection("user");
//查询所有文档
FindIterable<Document> allDocuments = userCollection.find();
//获取迭代器
MongoCursor<Document> iterator = allDocuments.iterator();
while (iterator.hasNext())
{
Document document = iterator.next();
System.out.println(document);
}
} /**
*
* @描述:有条件查询user集合数据
*/
@Test
public void testGet()
{
//获取users集合
MongoCollection<Document> userCollection = database.getCollection("user");
//查询age>=25 并且age <=30的人
Bson queryBson = Filters.and(Filters.gte("age", 25), Filters.lte("age", 30));
FindIterable<Document> allDocuments = userCollection.find(Filters.and(queryBson));
//获取迭代器
MongoCursor<Document> iterator = allDocuments.iterator();
while (iterator.hasNext())
{
Document document = iterator.next();
System.out.println(document);
}
} /**
*
* @描述:分页查询出users集合中的数据
*/
@Test
public void testGet2()
{
//获取users集合
MongoCollection<Document> userCollection = database.getCollection("user");
//查询前两个数据,skip(0):跳过0个,limit(2)查询2个
FindIterable<Document> allDocuments = userCollection.find();
FindIterable<Document> page = allDocuments.skip(0).limit(2);
//获取迭代器
MongoCursor<Document> iterator = page.iterator();
while (iterator.hasNext())
{
Document document = iterator.next();
System.out.println(document);
}
} /**
*
* @描述:修改操作
*/
@Test
public void update()
{
//获取user集合
MongoCollection<Document> userCollection = database.getCollection("user");
////修改 将userName为"lily" 的age改为25
//db.users.update({"userName":"lily"},{$set:{"age":25}});
//条件
Bson eqBson = Filters.eq("userName", "lily");
//要修改的内容
Document updateBson = new Document("$set", new Document("age", 25));
UpdateResult updateMany = userCollection.updateMany(eqBson, updateBson);
System.out.println(updateMany.toString());
} @After
public void close()
{
client.close();
} }

注意:本文仅代表个人理解和看法哟!和本人所在公司和团体无任何关系!

mongodb java操作常用写法的更多相关文章

  1. mongodb客户端操作常用命令(续)

    之前有写过一篇mongodb客户端的操作常用命令 ,今天接着来记录分享一些关于mongodb账户权限设置的命令操作 上期mongodb客户端的操作常用命令地址:https://www.cnblogs. ...

  2. Java代码常用写法总结

    1.字符串是否为空判断 以下是java 判断字符串是否为空的四种方法:方法一: 最多人使用的一个方法, 直观, 方便, 但效率很低: if(s == null ||"".equal ...

  3. mongodb客户端操作常用命令

    一启动mongodb数据库mongod --dbpath E:\mongo\data\db(这里些自己的mongodb数据库存放目录)二客户端操作1.显示数据库集合show dbs2.新建数据库use ...

  4. 6. MongoDB——Java操作(增删改查)

    转自:https://blog.csdn.net/kai402458953/article/details/79626148 import java.net.UnknownHostException; ...

  5. Java多线程常用写法,使用匿名内部类

    匿名内部类是基于抽象类和接口而言的. //匿名内部类(解决定义过多文件的问题,标准开发一个类就是一个文件) // new Runnable() { // @Override // public voi ...

  6. java 操作mongodb查询条件的常用设置

    java操作mongodb进行查询,常用筛选条件的设置如下: 条件列表:BasicDBList condList = new BasicDBList(); 临时条件对象:BasicDBObject c ...

  7. Java操作MongoDB

    上一篇文章: http://www.cnblogs.com/hoojo/archive/2011/06/01/2066426.html 介绍到了在MongoDB的控制台完成MongoDB的数据操作,通 ...

  8. mongDB基本命令和Java操作MongoDB

    上一篇博文<mongoDB安装>我们安装了mongoDB,现在来复习一下它的一些基本命令:mongoDB的bin目录加入到path之后,命令行中输入mongo: 然后我们进入正题 1.查看 ...

  9. java 对mongodb的操作

    java 对mongodb的操作 1.1连单台mongodb Mongo mg = newMongo();//默认连本机127.0.0.1  端口为27017 Mongo mg = newMongo( ...

随机推荐

  1. Python之向函数传递元组和字典

    也可以在函数定义时加上这两个参数用以接收多余的参数哦~

  2. C#关键字扫盲——Tuple(元组类) 、ValueTuple(值元组)

    原文:C#关键字扫盲--Tuple(元组类) .ValueTuple(值元组) 版权声明:本文为博主原创文章,随意转载. https://blog.csdn.net/Michel4Liu/articl ...

  3. UltraEdit常用快捷键

    UltraEdit是一套功能强大的文本编辑器,可以编辑文本.十六进制.ASCII码,可以取代记事本,内建英文单字检查.C++及VB指令突显,可同时编辑多个文件,而且即使开启很大的文件速度也不会慢. 说 ...

  4. concurrent=false/true的定时任务job策略介绍

    前言: 四种测试情况,cronExpression = 0/30 * * * * ? : 1,一个trigger,job设置的是每30s执行一次,实际需要75s:concurrent=false: 2 ...

  5. mysql中创建函数

    MySql创建函数 一.查看创建函数的功能是否开启: mysql> show variables like '%func%'; +-------------------------------- ...

  6. Hadoop(三)YARN

    Yet Another Resources Negotiator 从Hadoop2.0版本开始引入YARN,主要功能: 集群资源管理系统 负责集群的统一管理和调度 与客户端交互,处理客户端请求 一.基 ...

  7. Jenkins应用

    转自 https://www.cnblogs.com/syw20170419/category/1239520.html Jenkins+Git+Python 进行持续集成接口测试 https://w ...

  8. sql 修改数据

    关系数据库的基本操作就是增删改查,即CRUD:Create.Retrieve.Update.Delete.其中,对于查询,我们已经详细讲述了SELECT语句的详细用法. 而对于增.删.改,对应的SQL ...

  9. 【LeetCode 27】移除元素

    题目链接 [题解] 沙比提 [代码] class Solution { public: int removeElement(vector<int>& nums, int val) ...

  10. 树的直径变形——cf1238F

    /* 题目给定一些一维线段[li,ri],要求从这些线段里挑出一些线段,每条线段对应一个点,如果两线段相交,那么点连边,这样得到的树是good-tree 现在给定一棵树,要求从该树中选出一棵子树,使这 ...