MongoDB

MongoDB

什么是MongoDB

MongoDB是一个文档数据库 (以json为数据模型),由C++编写,旨在为WEB应用提供可扩展的高性能数据存储解决方案。

MongoDB是一个介于关系型数据库和非关系型数据库的之间的产品,是非关系型数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,数据格式是BSON,一种类似于JSON的二进制形式存储结构,简称Binary JSON,和JSON一样支持内嵌的文档对象和数组对象,因此可以存储比较复杂的数据类型。MongoDB最大的特点是它支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。原则上OracleMySQL能做的事情,MongoDB都能做 (包括ACID事务)


MongoDB技术优势

MongoDB基于灵活的JSON文档模型,非常适合敏捷式的快速开发。与此同时,其与生俱来的高可用、高水平扩展能力使得它在处理海量、高并发的数据应用时颇具优势。

  • JSON结构和对象模型接近,开发代码量低
  • JSON的动态模型意味着更容易响应新的业务需求
  • 复制集提供99.999%高可用
  • 分片架构支持海量数据和无缝扩容

MongoDB文档操作

插入文档
新增单个文档
  • insertOne:支持writeConcern

    db.collection.insertOne(
    	<document>,
      {
      	writeConcern: <document>
      }
    )
    

    writeConcern 决定一个写操作落到多少个节点上才算成功。writeConcern 的取值包括:

    0:发起写操作,不关心是否成功

    1-集群最大数据节点数:写操作需要被复制到指定节点数才算成功

    majority:写操作需要被复制到大多数节点上才算成功

  • Insert:若插入的数据主键已经存在,则会抛 DuplicateKeyException异常,提示主键重复,不保存当前数据

  • save:如果 _id 主键存在则更新数据,如果不存在就插入数据


批量新增文档
  • insertMany:向指定集合中插入多条文档数据

    db.collection.insertMany(
    	[ <document 1>, <document 2>, ... ]
      {
      	writeConcern: <document>
      	ordered: <boolean>
      }
    )
    

    writeConcern:写入策略,默认为1,即要求确认写操作,0是不要求

    ordered:指定是否按顺序写入,默认是true,按顺序写入

​ insert和save也可以实现批量插入


查询文档

find 查询集合中的若干文档。语法格式如下:

db.collection.find(query, projection)
  • query:可选,使用查询操作符指定查询条件
  • projection:可选,使用投影操作符指定返回的键。查询时返回文档中所有键值,只需省略该参数即可 (默认省略)。投影时,id为1的时候,其他字段必须是1;id是0的时候,其他字段可以是0;如果没有_id字段约束,多个其他字段必须同为0或同为1

findOne查询集合中的第一个文档。语法格式如下:

db.collection.findOne(query, projection)

更新文档

可以用update命令对指定的数据进行更新,命令的格式如下:

db.collection.update(query,update,options)
  • query:描述更新的查询条件
  • update:描述更新的动作及新的内容
  • options:描述更新的选项
    • upsert:可选,如果不存在uodate的记录,是否插入新的记录。默认false,不插入
    • multi:可选,是否按条件查询出的多条记录全部更新。默认为false,只更新找到的第一条记录
    • writeConcern:可选,决定一个写操作落到多少个节点才算成功

删除文档
使用remove删除文档
  • remove命令需要配合查询条件使用

  • 匹配查询条件的文档会被删除

  • 指定一个空文档条件会删除所有文档

    db.user.remove({age:28})    		// 删除age=28的记录
    db.user.remove({age:{$lt:25}})  // 删除age小于25的记录
    db.user.remove({ })						  // 删除所有记录
    db.user.remove()                // 报错
    
  • remove命令会删除匹配条件的全部文档,如果希望明确限定只删除一个文档,则需要指定justOne参数,命令格式如下

    db.collection.remove(query,justone)
    // eg
    db.books.remove({type:"nove1"},true)
    

使用delete删除文档

官方推荐使用deleteOne()deleteMany()来删除文档,语法格式如下

db.books.deleteMany({})                  // 删除集合下的全部文档
db.books.deleteMany({type:"novel"})      // 删除type等于novel的全部文档
db.books.deleteOne({type:"novel"})       // 删除type等于novel的一个文档

SpringBoot整合MongoDB

环境准备
  • 引入依赖

    <dependency>
      <groupId>org.springframework.book</groupId>
      <artifactId>spring-boot-starter-data-mongodb</artifactId>
    </dependency>
    
  • 配置yml

    spring:
      data: 
        mongodb:
        	uri: mongodb://root:root@127.0.0.1:27017/test?authSource=admin
          #uri等同于下面的配置
          #database: test
          #host: 127.0.0.1
          #port: 27017
          #username: root
          #password: root
          #authentication-database: admin
    
  • 使用时注入mongodbTemplate

    @Autowired
    MongoTemplate mongoTemplate;
    
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值