MongoDB操作(1)—MongoDB java驱动核心层次结构及操作流程
- MongoDB之java驱动学习
- 预备:
- 本地运行MongoDB采用默认端口20717;
- 安装MongoDB驱动;
- 以下关键步骤。
- 核心层次结构或步骤:
- 创建连接池:MongoClient实例。
- 对于一个给定的MongoDB部署{独立的MongoDB,副本,分片集群},连接池实例只需要一个。
- 如果创建了多实例连接池:
- 资源限制:每个连接池实例对资源的使用都将受到限制(如最大连接数)。
- 关闭连接池:要放弃一个连接池实例,就应该调用MongoClient.close()方法来清除资源。
- 访问数据库:MongoClient.getDatabase()方法的调用
- 在方法中指定数据库名字。如果该数据库不存在,MongoDB会在你第一次存储数据到该数据库时创建该数据库。
- getDatabase()方法返回的MongoDatabase对象是不可变的。
- 访问集合(~表):使用MonoDatabase的getCollection()方法访问一个集合Collection。
- 在getCollection()方法中声明集合的名字。如果一个集合不存在,MongoDB会在你第一次存储数据到该集合的时候创建该集合。
- MongoCollection对象是不可变的。
- 创建一个文档Document(~记录)
- Document对象包含许多字符串类型参数,字符串池的管理是否会存在压力?
- 插入一个文档(记录)到集合(表)当中 :collection.insertOne(doc)
- 创建连接池:MongoClient实例。
- 预备:
- 增删改查详解:
- 增:
- 单个文档插入collection.insertOne(doc),略;
- 多个文档插入:
- collection.insertMany(list);
- for循环、foreach;
- 查询:
- 集合中的文档数量:collection.countDocuments();
- 查找单个文档:collection.find()
- 配合first()方法:collection.find().first();
- 如果没记录,返回null:
- 查找所有的文档:collection.find.iterator()
- 返回类型为MongoCursor;
- 迭代方式:
- while(cursor.hasNext()){cursor.next().toJson()},finally中关闭游标;
- foreach循环:应当避免使用,因为如果循环提前结束,会导致游标泄漏。
- 查找满足特定条件的文档:find()方法中传入过滤器
- eq(fieldName,valueConditioin);
- 范围过滤器:and(gt(field1Name,value1),lte(filed2Name,value2)).foreach();
- 更新文档
- updateOne:
- updateMany:
- 返回UpdateResult对象;
- 更新必传参数:
- 过滤器对象;
- 要更新的文档对象。
- 删除文档
- deleteOne;
- deleteMany;
- 必传参数:过滤器对象
- 增:
- 创建索引
- 为了在一个字段或多个字段上创建索引,传一个索引声明文档到createInde()方法中。
- 一个索引文档包含要索引的字段名,以及每个字段的索引类型:
- 1,升序的索引类型;
- -1,降序的索引类型。
MongoDB操作(1)—MongoDB java驱动核心层次结构及操作流程的更多相关文章
- Mongodb入门并使用java操作Mongodb
转载请注意出处:http://blog.csdn.net/zcm101 最近在学习NoSql,先从Mongodb入手,把最近学习的总结下. Mongodb下载安装 Mongodb的下载安装就不详细说了 ...
- MongoDB的Java驱动使用整理 (转)
MongoDB Java Driver 简单操作 一.Java驱动一致性 MongoDB的Java驱动是线程安全的,对于一般的应用,只要一个Mongo实例即可,Mongo有个内置的连接池(池大小默认为 ...
- mongodb在java驱动包下的操作(转)
推荐几章很有用的文章 java操作参考文档 http://www.cnblogs.com/hoojo/archive/2011/06/02/2068665.html http://blog.csdn. ...
- MongoDB学习-->命令行增删改查&JAVA驱动操作Mongodb
MongoDB 是一个基于分布式文件存储的数据库. 由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关 ...
- mongodb高级操作及在Java企业级开发中的应用
Java连接mongoDB Java连接MongoDB需要驱动包,个人所用包为mongo-2.10.0.jar.可以在网上下载最新版本. package org.dennisit.mongodb.st ...
- MongoDB资料--Java驱动, Hadoop驱动, Spark使用
MongoDB数据库备份: mongodump -h 192.168.1.160 -d MapLoc -o /usr/local/myjar/mongo/MapLoc/数据库还原:mongoresto ...
- MongoDB学习比较-07 C#驱动操作MongoDB
下载驱动 驱动的下载有两种方式:一种是在C#项目中通过NuGet进行安装,另一种是通过下面的链接:https://github.com/mongodb/mongo-csharp-driver/rele ...
- java操作mongodb & springboot整合mongodb
简单的研究原生API操作MongoDB以及封装的工具类操作,最后也会研究整合spring之后作为dao层的完整的操作. 1.原生的API操作 pom.xml <!-- https://mvnre ...
- MongoDB(3)--Java 操作 MongoDB 的 API
引入mongoDb 依赖 <dependency> <groupId>org.mongodb</groupId> <artifactId>mongo-j ...
随机推荐
- 关于发邮件报错535 Error:authentication failed解决方法
写在最前面 相信看到535报错的同学代码编写方面都没有问题,只是不明白为什么填写了帐号密码后还是报535错误,这里我以163邮箱为例,并使用Python讲解怎么解决535问题 代码如下: import ...
- Python中的Numpy入门教程
1.Numpy是什么 很简单,Numpy是Python的一个科学计算的库,提供了矩阵运算的功能,其一般与Scipy.matplotlib一起使用.其实,list已经提供了类似于矩阵的表示形式,不过nu ...
- access数据库查找以及如果结果中存在多个匹配用户该怎么处理?
查找用户的界面为: 首先对查找条件进行赋值: if (radioButton1.Checked) serMatchInfo = "用户姓名"; if (radioButton2.C ...
- SpringCloudStream实战
Spring Cloud Stream是一个用于构建消息驱动的微服务应用程序的框架.Spring Cloud Stream构建于Spring Boot之上,用于创建独立的生产级Spring应用程序,并 ...
- ASP MD5
<% Private Const BITS_TO_A_BYTE = 8 Private Const BYTES_TO_A_WORD = 4 Private Const BITS_TO_A_WOR ...
- Spring使用MappingJackson2MessageConverter发送接收ActiveMQ消息
一.Spring使用JmsTemplate简化对JMS的访问 在JAVA对JMS队列访问中,使用默认的JMS支持将存在大量的检查型异常.通过Spring的支持,可以将所有的JMS的检查型异常转换为运行 ...
- 如何利用snmp协议发现大型复杂环境的网络拓扑
参考文献:http://blog.51cto.com/13769225/2121431 获取指标参考下图: 1.取接口描述(指定VLAN号) 命令:snmpwalk -v 2c -c Cvicse12 ...
- 03-HTML之body标签
body标签 HTML标签按作用主要分为两类:字体标签和排版标签 HTML标签按级别主要分为两类:文本级标签和容器级标签 文本级标签:p.span.a.b.i.u.em.文本标签里只能放文字.图片.表 ...
- transfer.sh:通过命令行简单的创建文件分享
简介 通过一个命令,就可以在终端上,将文件加密传输到远程服务器,提供对外文件共享的功能. transfer.sh这是一个我常用的.可以在终端上使用的文件共享服务,可以在某些方面替代sz或者scp命令. ...
- AtCoder Beginner Contest 122 D - We Like AGC (DP)
D - We Like AGC Time Limit: 2 sec / Memory Limit: 1024 MB Score : 400400 points Problem Statement Yo ...