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 ...
随机推荐
- Linux分区的几种方案
通用方法/boot 引导分区 200M swap 交换分区 内存的1.5倍(内存小于8G) 大于8G 给8G/ 根分区 剩下多少给多少 数据非常重要/bootswap/ 50-200G/data 剩下 ...
- 自己动手写处理器之第二阶段(1)——可编程逻辑器件与PLD电路设计流程
将陆续上传本人写的新书<自己动手写处理器>(尚未出版),今天是第五篇,我尽量每周四篇 通过上一章的介绍,读者应该知道CPU内部有一些主要的电路,比方:译码电路.运算电路.控 ...
- [JXOI2018]游戏
嘟嘟嘟 九条可怜竟然有这种良心题,似乎稍稍刷新了我对九条可怜的认识. 首先假设我们求出了所有必须要筛出来的数m,那么\(t(p)\)就只受最后一个数的位置影响. 所以我们枚举最后一个数的位置,然后用组 ...
- 转://oracle deadlock死锁trace file分析之一
---oracle versionSQL> select * from v$version where rownum=1;BANNER------------------------------ ...
- @ModelAttribute
在执行Controller方法前都会新建一个Map对象称为隐含模型,该Map对象是共享的,如果一个方法的入参为Map ModelAndMap ModelMap等类型,那么会把隐含模型当做入参赋给方法. ...
- 路飞学城-Python开发集训-第4章
学习心得: 学习笔记: 在python中一个py文件就是一个模块 模块好处: 1.提高可维护性 2.可重用 3.避免函数名和变量名冲突 模块分为三种: 1.内置标准模块(标准库),查看所有自带和第三方 ...
- gcc 找不到 boot python 链接库的问题: /usr/bin/ld: cannot find -lboost_python
问题: Ubuntu 14.04,gcc 4.8.4,以默认方式编译 boost 1.67 后,使用 Boost.Python 时,gcc 提示找不到 boost python 链接库. 方案: 查看 ...
- 理解JSON Web Token (一)
一:理解单系统登录的原理及实现? web应用采用的 browser/server 架构的,http是无状态协议的,也就是说用户从A页面跳转到B页面会发起http请求,当服务器返回响应后,当用户A继续访 ...
- redis学习(六)——Sorted Set数据类型
一.概述: Sorted Set(有序集合)和Set类型极为相似,它们都是字符串的集合,都不允许重复的成员出现在一个Set中.它们之间的主要差别是Sorted Set中的每一个成员都会有一个分数(sc ...
- 【C#复习总结】细说委托
1 前言 本系列会将[委托] [匿名方法][Lambda表达式] [泛型委托] [表达式树] [事件]等基础知识总结一下.(本人小白一枚,有错误的地方希望大佬指正) 系类1:细说委托 系类2:细说匿名 ...