• MongoDB之java驱动学习

    • 预备:
      1. 本地运行MongoDB采用默认端口20717;
      2. 安装MongoDB驱动;
      3. 以下关键步骤。
    • 核心层次结构或步骤:
      1. 创建连接池:MongoClient实例。

        • 对于一个给定的MongoDB部署{独立的MongoDB,副本,分片集群},连接池实例只需要一个。
        • 如果创建了多实例连接池:
          1. 资源限制:每个连接池实例对资源的使用都将受到限制(如最大连接数)。
          2. 关闭连接池:要放弃一个连接池实例,就应该调用MongoClient.close()方法来清除资源。
      2. 访问数据库:MongoClient.getDatabase()方法的调用
        • 在方法中指定数据库名字。如果该数据库不存在,MongoDB会在你第一次存储数据到该数据库时创建该数据库。
        • getDatabase()方法返回的MongoDatabase对象是不可变的。
      3. 访问集合(~表):使用MonoDatabase的getCollection()方法访问一个集合Collection。
        • 在getCollection()方法中声明集合的名字。如果一个集合不存在,MongoDB会在你第一次存储数据到该集合的时候创建该集合。
        • MongoCollection对象是不可变的。
      4. 创建一个文档Document(~记录)
        • Document对象包含许多字符串类型参数,字符串池的管理是否会存在压力?
      5. 插入一个文档(记录)到集合(表)当中 :collection.insertOne(doc)

  • 增删改查详解:

    • 增:

      • 单个文档插入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对象;
      • 更新必传参数:
        1. 过滤器对象;
        2. 要更新的文档对象。
    • 删除文档
      • deleteOne;
      • deleteMany;
      • 必传参数:过滤器对象

  • 创建索引

    • 为了在一个字段或多个字段上创建索引,传一个索引声明文档到createInde()方法中。
    • 一个索引文档包含要索引的字段名,以及每个字段的索引类型:
      1. 1,升序的索引类型;
      2. -1,降序的索引类型。

MongoDB操作(1)—MongoDB java驱动核心层次结构及操作流程的更多相关文章

  1. Mongodb入门并使用java操作Mongodb

    转载请注意出处:http://blog.csdn.net/zcm101 最近在学习NoSql,先从Mongodb入手,把最近学习的总结下. Mongodb下载安装 Mongodb的下载安装就不详细说了 ...

  2. MongoDB的Java驱动使用整理 (转)

    MongoDB Java Driver 简单操作 一.Java驱动一致性 MongoDB的Java驱动是线程安全的,对于一般的应用,只要一个Mongo实例即可,Mongo有个内置的连接池(池大小默认为 ...

  3. mongodb在java驱动包下的操作(转)

    推荐几章很有用的文章 java操作参考文档 http://www.cnblogs.com/hoojo/archive/2011/06/02/2068665.html http://blog.csdn. ...

  4. MongoDB学习-->命令行增删改查&JAVA驱动操作Mongodb

    MongoDB 是一个基于分布式文件存储的数据库. 由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关 ...

  5. mongodb高级操作及在Java企业级开发中的应用

    Java连接mongoDB Java连接MongoDB需要驱动包,个人所用包为mongo-2.10.0.jar.可以在网上下载最新版本. package org.dennisit.mongodb.st ...

  6. MongoDB资料--Java驱动, Hadoop驱动, Spark使用

    MongoDB数据库备份: mongodump -h 192.168.1.160 -d MapLoc -o /usr/local/myjar/mongo/MapLoc/数据库还原:mongoresto ...

  7. MongoDB学习比较-07 C#驱动操作MongoDB

    下载驱动 驱动的下载有两种方式:一种是在C#项目中通过NuGet进行安装,另一种是通过下面的链接:https://github.com/mongodb/mongo-csharp-driver/rele ...

  8. java操作mongodb & springboot整合mongodb

    简单的研究原生API操作MongoDB以及封装的工具类操作,最后也会研究整合spring之后作为dao层的完整的操作. 1.原生的API操作 pom.xml <!-- https://mvnre ...

  9. MongoDB(3)--Java 操作 MongoDB 的 API

    引入mongoDb 依赖 <dependency> <groupId>org.mongodb</groupId> <artifactId>mongo-j ...

随机推荐

  1. 配置数据库方言——hibernate

    RDBMS 方言 DB2 org.hibernate.dialect.DB2Dialect DB2 AS/400 org.hibernate.dialect.DB2400Dialect DB2 OS3 ...

  2. spool

    一.常用设置 set lin 1000 --一行可容纳字符数{80|n};输出大于设置值,则折行显示set wrap on --输出行长度大于设置长度时(set lin n设置);值为on,多余字符另 ...

  3. P1145 约瑟夫 W(模拟)

    暴力+模拟 #include<iostream> #include<cstring> using namespace std; int ans, k, k2; ]; bool ...

  4. L2-012 关于堆的判断 (25 分)

    就是一个最小根堆. 最小根堆的性质,根节点小于等于子树的完全二叉树吧. 构建最小根堆的过程就是一个自下向上的过程. #include<iostream> #include<strin ...

  5. 002_cookie的session_id解释

    HTTP协议(http://www.w3.org/Protocols/)是“一次性单向”协议. 服务端不能主动连接客户端,只能被动等待并答复客户端请求.客户端连接服务端,发出一个HTTP Reques ...

  6. ORA-16433 The database must be opened in read write mode故障解决

    转 一.首先删除原有控制文件并新建控制文件 1.找到控制文件位置 SQL> show parameter control_files; NAME TYPE VALUE ------------- ...

  7. windows下彻底删除jenkins

    1.在控制面板中选择卸载jenkins 2.重启电脑 3.找到“.jenkins”(在C盘寻找) 4.删除“.jenkins” 5.是否要删除环境变量?(目前没删除) 6.jenkins再安装使用的是 ...

  8. 总结一下linux中的分段机制

    本文为原创,转载请注明:http://www.cnblogs.com/tolimit/ 这篇文章主要说一下linux对于分段机制的处理,虽然都说linux不使用分段机制,但是分段机制属于CPU的一个功 ...

  9. OGC标准服务 WMS WCS WFS WPS

    网络覆盖服务 (WCS) 网络要素服务 (WFS) 网络地图服务 (WMS) 网络地图切片服务 (WMTS) 网络处理服务 (WPS) 1.Web 地图服务(WMS)能够根据用户的请求返回相应的地图( ...

  10. Java多线程学习(二)---线程创建方式

    线程创建方式 摘要: 1. 通过继承Thread类来创建并启动多线程的方式 2. 通过实现Runnable接口来创建并启动线程的方式 3. 通过实现Callable接口来创建并启动线程的方式 4. 总 ...