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 ...
随机推荐
- 配置数据库方言——hibernate
RDBMS 方言 DB2 org.hibernate.dialect.DB2Dialect DB2 AS/400 org.hibernate.dialect.DB2400Dialect DB2 OS3 ...
- spool
一.常用设置 set lin 1000 --一行可容纳字符数{80|n};输出大于设置值,则折行显示set wrap on --输出行长度大于设置长度时(set lin n设置);值为on,多余字符另 ...
- P1145 约瑟夫 W(模拟)
暴力+模拟 #include<iostream> #include<cstring> using namespace std; int ans, k, k2; ]; bool ...
- L2-012 关于堆的判断 (25 分)
就是一个最小根堆. 最小根堆的性质,根节点小于等于子树的完全二叉树吧. 构建最小根堆的过程就是一个自下向上的过程. #include<iostream> #include<strin ...
- 002_cookie的session_id解释
HTTP协议(http://www.w3.org/Protocols/)是“一次性单向”协议. 服务端不能主动连接客户端,只能被动等待并答复客户端请求.客户端连接服务端,发出一个HTTP Reques ...
- ORA-16433 The database must be opened in read write mode故障解决
转 一.首先删除原有控制文件并新建控制文件 1.找到控制文件位置 SQL> show parameter control_files; NAME TYPE VALUE ------------- ...
- windows下彻底删除jenkins
1.在控制面板中选择卸载jenkins 2.重启电脑 3.找到“.jenkins”(在C盘寻找) 4.删除“.jenkins” 5.是否要删除环境变量?(目前没删除) 6.jenkins再安装使用的是 ...
- 总结一下linux中的分段机制
本文为原创,转载请注明:http://www.cnblogs.com/tolimit/ 这篇文章主要说一下linux对于分段机制的处理,虽然都说linux不使用分段机制,但是分段机制属于CPU的一个功 ...
- OGC标准服务 WMS WCS WFS WPS
网络覆盖服务 (WCS) 网络要素服务 (WFS) 网络地图服务 (WMS) 网络地图切片服务 (WMTS) 网络处理服务 (WPS) 1.Web 地图服务(WMS)能够根据用户的请求返回相应的地图( ...
- Java多线程学习(二)---线程创建方式
线程创建方式 摘要: 1. 通过继承Thread类来创建并启动多线程的方式 2. 通过实现Runnable接口来创建并启动线程的方式 3. 通过实现Callable接口来创建并启动线程的方式 4. 总 ...