MongoDB-----简介、数据库的操作以及文档的操作

本文介绍了MongoDB,一种基于分布式文件存储的开源数据库系统,适用于高负载环境下的高性能数据存储。MongoDB采用文档存储方式,支持丰富的查询表达式,易于扩展和分布式部署。文章详细讲解了MongoDB的数据库、集合和文档操作,包括创建、查询、更新和删除等关键操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

什么是MongoDB ?(引用菜鸟教程

MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。

在高负载的情况下,添加更多的节点,可以保证服务器性能。

MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。

MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。
主要特点

  1. MongoDB 是一个面向文档存储的数据库,操作起来比较简单和容易。
  2. 你可以在MongoDB记录中设置任何属性的索引 (如:FirstName=“Sameer”,Address=“8 Gandhi Road”)来实现更快的排序。
  3. 你可以通过本地或者网络创建数据镜像,这使得MongoDB有更强的扩展性。
  4. 如果负载的增加(需要更多的存储空间和更强的处理能力) ,它可以分布在计算机网络中的其他节点上这就是所谓的分片。
  5. Mongo支持丰富的查询表达式。查询指令使用JSON形式的标记,可轻易查询文档中内嵌的对象及数组。
  6. MongoDb 使用update()命令可以实现替换完成的文档(数据)或者一些指定的数据字段 。
  7. Mongodb中的Map/reduce主要是用来对数据进行批量处理和聚合操作。
  8. Map和Reduce。Map函数调用emit(key,value)遍历集合中所有的记录,将key与value传给Reduce函数进行处理。
  9. Map函数和Reduce函数是使用Javascript编写的,并可以通过db.runCommand或mapreduce命令来执行MapReduce操作。
  10. GridFS是MongoDB中的一个内置功能,可以用于存放大量小文件。
  11. MongoDB允许在服务端执行脚本,可以用Javascript编写某个函数,直接在服务端执行,也可以把函数的定义存储在服务端,下次直接调用即可。
  12. MongoDB支持各种编程语言:RUBY,PYTHON,JAVA,C++,PHP,C#等多种语言。
  13. MongoDB安装简单。

语言支持
MongoDB有官方的驱动如下:

C
C++
C# / .NET
Erlang
Haskell
Java
JavaScript
Lisp
node.JS
Perl
PHP
Python
Ruby
Scala

数据库操作

  1. 创建数据库

    use 数据库名字------如果数据库不存在则创建,存在则切换

  2. 查看所有数据库(空数据库不显示)
    show dbs

  3. 查看当前使用的数据库
    db

  4. 要显示新创建的数据库,至少插入一个文档
    db.items.insert({’‘key’’:“value”})
    key value 是键值对

  5. 删除数据库
    db.dropDatabase() ------- 删除现有数据库

数据库中集合操作

  1. 创建一个MongoDB数据库中集合
    格式:
    db.createCollection(name,options)

    name----string-----要创建数据库的名称
    options-----Document-----可选,指定有关内存大小和索引选项

字段类型描述
cappedbollean如果true—>启用封闭的集合,上限集合的固定大小,和size参数联用
size数字指定上限集合的最大大小(字节)
max数字上限集合中允许存储的最大文档数
autoIndexIdBoolean可选,如果true,创建字段_id 并自动创建索引 默认为false

db.createClooection(‘mycol’,{capped:true,autoIndexId:true,size:6140000,max:10000})

  1. 显示当前数据库所有集合
    show collections

  2. 删除集合
    db.集合名字.drop()
    db.collection.drop()----删除当前集合

    如果删除成功----true
    删除失败-----false

文档操作

  1. 插入文档
    两种方式: insert() , save()

    insert()格式:
    db.集合名字.insert(内容插入)
    例如:mycol集合
    db.mycol.insert({_id:100,title:‘mongodb overview’,description:‘mongodb is no sql database’,url:‘http://www.baidu.com’,tags:[‘mongodb’,‘database’,‘nosql’],likes:100,})

    save()格式:
    db.post.save(document)

    3.2 版本至少在3.2
    insertone()----可以插入单个文本
    insertmany()----可以插入多个文本

  2. 查询文档
    要从mongodb中集合中查询数据----》find()

    格式:
    db.collection_name.find()
    find()----查询----返回是一个非结构化的显示所有的文档

    db.collection_name.find().pretty()---->格式化显示查询的数据

  3. mongoDb和RDBMS的等效的where语句
    relational database management system(关系型数据库管理系统)

    mysql:
    select * from mycol where _id=104;

    mongodb:
    db.mycol.find(过滤的规则)

    (1) 过滤规则
    在这里插入图片描述 (2)mongodb中and操作符

    (3)mongodb中or操作符

    (4)使用and和or条件一起使用

更新中…

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值