MongoDB的基本操作实例详解【服务端启动,客户端连接,CRUD操作】

本文实例讲述了MongoDB的基本操作。分享给大家供大家参考,具体如下:

本文内容:

  • MongoDB的介绍
  • MongoDB服务端的启动
  • MongoDB客户端连接
  • SQL与MongoDB相关概念解释
  • 什么是BSON
  • 数据库操作
  • 集合操作
  • 文档操作

测试环境:win10

软件版本:3.6.2

首发时间:2018-03-18 15:38


MongoDB的介绍:

  • MongoDB 是由C++语言编写的开源数据库系统。
  • MongoDB 将数据存储为一个文档。MongoDB是一个基于分布式文件存储的数据库。
  • MongoDB的提供了一个面向文档存储,操作起来比较简单和容易
  • 可以在MongoDB记录中设置任何属性的索引
  • Mongo支持丰富的查询表达式。查询指令使用JSON形式的标记,可轻易查询文档中内嵌的对象及
    数组。
  • MongoDB支持多个存储引擎:wireTiger、 MMaPv1等等

MongoDB服务端的启动:

使用mongod命令来启动服务端

  • mongodb常用启动参数

    • --bind_ip:绑定服务IP,若绑定127.0.0.1,则只能本机访问,不指定默认本地所有IP

    • --port:指定服务端口号,默认端口27017

    • --logpath:指定MongoDB日志文件存放路径

    • --dbpath:指定数据库路径【需要指定才能启动成功】

    • --serviceName:指定服务名称 【主要用于安装服务时指定名称】

    • --serviceDisplayName:指定服务名称,有多个mongodb服务时执行。【主要用于安装服务时指定名称】

想获得更多参数信息,可以输入:

mongod --help
或
mongod -h

将MongoDB服务器作为Windows服务运行:

上面的启动方式需要挂起一个窗口。

如果不想一直挂起一个窗口,也可以将这些启动参数添加到服务中,将mongod作为一个服务启动,这样就不需要那么麻烦了。

输入命令例子如下:

mongod --dbpath "D:\data\db" --logpath "D:\data\log\mongodb.log" --serviceName "mongodb" --serviceDisplayName "mongodb" --install
  • 安装服务必须参数介绍:

    • --install:指示安装成服务
    • --serviceName:指定服务名称
    • --serviceDisplayName:指定服务名称,有多个mongodb服务时执行
    • 其他设置都是可选的,按自己需求来确认是否填写。

这样就只需要在使用的时候启动mongod服务即可。


MongoDB客户端连接:

使用mongo命令来连接服务端。

mongo [options] [db address] [file names (ending in .js)]
本地服务端可以使用:mongo 或者mongo localhost
远程的可以使用:mongo IP地址

想获取更多参数设置信息,可以输入一下命令:

mongo --help
或
mongo -h

SQL与MongoDB相关概念解释:

这个相关概念解释是为了让一些有了SQL学习经验(没有的应该也能了解)的人更快了解MongoDB的结构


什么是BSON:

  • BSON()是一种类json的一种二进制形式的存储格式,简称Binary JSON,它和JSON一样,支持内嵌的文档对象和数组对象,但是BSON有JSON没有的一些数据类型,如Date和BinData类型。
  • BSON可以做为网络数据交换的一种存储形式,这个有点类似于Google的Protocol Buffer,但是BSON是一种schema-less的存储形式,它的优点是灵活性高,但它的缺点是空间利用率不是很理想,
  • BSON有三个特点:轻量性、可遍历性、高效性
  • BSON的例子:{"name":"alex","age":18}
  • BSON支持的数据类型:

数据库操作:

  • 显示所有数据库【注意,数据为空的数据库默认不显示出来】:

    show dbs

  • 显示当前数据库对象或者集合:

    db

  • 切换数据库,如果数据库不存在就创建数据库再切换到指定数据库:

    use 数据库名

  • 创建数据库: use 数据库名
    • 数据库名称可以是任何字符,但是不能包含空字符串,点号(.),或者" "。
    • 默认的数据库为test,如果你没有创建新的数据库,集合将存放在test数据库中
  • 删除数据库:
    • db.dropDatabase():删除当前数据库,建议先用db命令确认一下当前数据库

集合操作:

  • 在mongodb中的集合是无模式的,mongodb中并没有严格的约束插入的数据,集合中存储的文档的结构可以是不同的。

    • 下面的两个文档可以同时存入到一个集合中:{"name":"alex"} {"age":18,"sex":"man"}
  • 集合的命名:

    • 集合名称必须以字母或下划线开头。
    • 集合名可以保护数字
    • 集合名称不能使美元符"$","$"是系统保留字符。
    • 集合的名字 最大不能超过128个字符 。
    • 另外,"."号的使用在集合当中是允许的,它们被成为子集合(Subcollection);
    • 创建集合:
db.createCollection(name, {size: ..., capped: ..., max: ...})
    • name是集合名
    • size,capped,max是可选项:size代表集合大小,capped代表是否限制集合大小(size来设置),max代表集合的最大文档数量
    • 可选项还有很多,想了解更多可以参考官方文档,比如还有storageEngine,collation。。。
  • 查看当前数据库所有集合:

    show collections

  • 删除集合:

    db.集合名.drop()

  • 修改集合名:

    db.集合名.renameCollection()

  • 获取集合帮助信息:

    db.集合名.help()


文档操作:

  • 插入文档:

    • db.集合名.insert(document):document是一个BSON格式的。

      db.users.insertOne({ name: "sue",age: 19,status: "P"})

    • db.集合名.insertOne(document):document是一个BSON格式的。

      db.teacher.insert({name: "sue"})
      db.teacher.insert([{"name":"Lili"},{"name":"Alex"}])

    • db.集合名.insertMany([document,document,document……]):document是一个BSON格式的。

      db.users.insertMany( [{ name: "bob", age: 42, status: "A", },{ name: "ahn", age: 22, status: "A", },{ name: "xi", age: 34, status: "D", }])

  • 查看数据:

    • db.集合名.find(<query filter>, <projection>)
    • db.集合名.findone(<query filter>, <projection>):只返回一个文档
    • query filter可以有如下:
      • {}:代表返回所有文档,db.集合名.find({}),等价于db.集合名.find()

        db.teacher.find()

      • {key1:value1,key2:value2…}:返回key1==value1 and key2==value2的文档;

        db.teacher.find({name:"alex"})
        db.teacher.find({name:"jack",course:"linux"})

      • { <key1>: { <operator1>: <value1> }, ... }:
        • operator可以有 $lt小于, $gt大于,$gte大于等于, $lte小于等于, $ne不等于

          db.class.find({"member":{$gt:5}})
          db.class.find({"member":{$gt:5},grade:{$gt:3}})

    • query filter多个条件的andor

      • 默认情况多个条件下是and的,多个条件用逗号分开
      • 如果想要使用or:{$or[{<key>:<value>},{<key>:<value>},{<key>:<value>}……]}
      • andor的联合使用: ({and条件,$or:[or条件]})
      • db.teacher.find({course:"linux",$or:[{name:"Lili"},{name:"Alex"}]})

    • query filter的条件还可以是类型检测:使用$type来进行类型检测,type检测的类型数字,根据上面BSON类型表中的数值。
      • 筛选出字段数据类型是否是double型的: $type:1
      • 筛选出字段数据类型是否是string型的: $type:2
      • 筛选出字段数据类型是否是boolean型的: $type:8
      • 筛选出字段数据类型是否是Null型的: $type:10
      • …..其他
    • 如果想要以格式化的方式来查看文档db.集合名.find().pretty()
      • 普通格式:
      • pretty格式:
  • 更新文档:

    • 更新文档可以使用下面几个:

      • db.集合名.updateOne(<query>,<update>,{option}):更新单条文档
      • db.集合名.updateMany(<query>,<update>,{option}):更新多条文档
      • db.集合名.update(<query>,<update>,{option}):更新文档,可选单条文档或多条文档
    • query是BSON格式的,作为查找文档的条件 ,query的条件参考上面查找文档中的query filter
    • update是BSON格式的,指明了如何修改文档 ,修改哪些字段
      •   注意,修改字段值需要加上{$set:{"key":"newvalue"}},不然{key:"newvalue"}会替换原来的文档,导致其他字段数据丢失
    • option:
      • upsert是如果对应不存在要修改的数据,是否将新的数据插入。默认是false不插入
      • db.集合名.update()中的multi是默认是false,只更新查找到的第一条文档数据,如果改成true,将更新所有可匹配的文档。
      • writeConcern是抛出异常的级别。
  • 删除数据:

    • db.集合名.remove(query):删除所有符合条件的文档

      • query :删除的文档的条件。如果条件为{},则删除所有文档 ,query可以参考查找文档中的query filter
      • justOne : (可选)如果设为 true 或 1,则只删除一个文档。
      • writeConcern :(可选)抛出异常的级别。


想了解更多可以参考官方文档。https://docs.mongodb.com/manual/reference/bson-types/

希望本文所述对大家MongoDB数据库程序设计有所帮助。

(0)

相关推荐

  • MongoDB.NET 2.2.4驱动版本对Mongodb3.3数据库中GridFS增删改查

    本文实例为大家分享了针对Mongodb3.3数据库中GridFS增删改查,供大家参考,具体内容如下 Program.cs代码如下: internal class Program { private static void Main(string[] args) { GridFSHelper helper = new GridFSHelper("mongodb://localhost", "GridFSDemo", "Pictures"); #re

  • PHP简单操作MongoDB的方法(安装及增删改查)

    本文实例讲述了PHP简单操作MongoDB的方法.分享给大家供大家参考,具体如下: php操作MongoDB的话首先从网上下载MongoDB的扩展包,https://github.com/mongodb/mongo-php-driver/downloads,选择对应的扩展包. 这是我下的,然后解压,VC6适合apache,VC9适合IIS,ts(thread safe)指PHP以模块形式运行的. 然后把其中的php_mongo.dll放在PHP中的ext文件夹中,然后在PHP.INI里面加入ex

  • MongoDB简单操作示例【连接、增删改查等】

    本文实例讲述了MongoDB简单操作.分享给大家供大家参考,具体如下: MongoDB 中默认的数据库为 test,连接后尝试以下操作 连接 插入数据:用过json的同学看到这格式相信不会陌生吧! db.person.insert({"name":"jack","age":22}) db.person.insert({"name":"Mary","age":22}) 查: db.pers

  • mongodb+php实现简单的增删改查

    windows上安装mongodb的php扩展 下载地址https://s3.amazonaws.com/drivers.mongodb.org/php/index.html 找到对应的php版本的dll文件,下载php_mongo.dll,放到php安装目录下的ext目录中,修改php.ini,添加一项extension=php_mongo.dll,没有找到支持php7的dll 获取MongoClient对象,new出来 获取数据库对象db,通过MongoClient对象的数据库属性,$Mon

  • java连接Mongodb实现增删改查

    本文实例为大家分享了java连接Mongodb实现增删改查的具体代码,供大家参考,具体内容如下 1.创建maven项目 <dependency> <groupId>org.mongodb</groupId> <artifactId>mongodb-driver</artifactId> <version>3.4.1</version> </dependency> 2.编写代码 1.查询所有 package co

  • koa+mongoose实现简单增删改查接口的示例代码

    配合上一篇文章的联系人应用(https://www.jb51.net/article/161160.htm),实现配套的基于nodejs的后台增删改查接口 1. 所需工具 node.js mongoDB 2. 主要node模块 koa(https://koa.bootcss.com,一个nodejs的开发框架),mongoose(https://mongoosejs.com,mongDB操作工具) 3. 目录结构 4. 启动MongoDB 首先在MongoDB安装盘的根目录下(这里假设是D盘)新

  • MongoDB服务端JavaScript脚本使用方法

    常用JavaScript语句 复制代码 代码如下: db.getSiblingDB(<dbname>)   db.getCollectionNames()    db.getCollection(<collname>)    db.printCollectionStats() 在mongo shell运行JavaScript脚本   切换数据库: 复制代码 代码如下: use <dbname> 运行如下脚本: var total = 0; var dbaStatColl

  • mongodb增删改查详解_动力节点Java学院整理

    仔细观察"划线区域"的信息,发现db文件夹下有一个类似的"lock file"阻止了mongodb的开启,接下来我们要做的就是干掉它,之后,开启成功,关于mongodb的管理方式将在后续文章分享. 一: Insert操作 上一篇也说过,文档是采用"K-V"格式存储的,如果大家对JSON比较熟悉的话,我相信学mongodb是手到擒来,我们知道JSON里面Value 可能是"字符串",可能是"数组",又有可能是

  • Node.js对MongoDB进行增删改查操作的实例代码

    MongoDB简介 MongoDB是一个开源的.文档型的NoSQL数据库程序.MongoDB将数据存储在类似JSON的文档中,操作起来更灵活方便.NoSQL数据库中的文档(documents)对应于SQL数据库中的一行.将一组文档组合在一起称为集合(collections),它大致相当于关系数据库中的表. 除了作为一个NoSQL数据库,MongoDB还有一些自己的特性: •易于安装和设置 •使用BSON(类似于JSON的格式)来存储数据 •将文档对象映射到应用程序代码很容易 •具有高度可伸缩性和

  • mongoDB中CRUD的深入讲解

    前言 今天开始接触非关系型数据库的mongoDB,现在将自己做的笔记发出来,供大家参考,也便于自己以后忘记了可以查看. 首先,mongoDB,是一种数据库,但是又区别与mysql,sqlserver.orcle等关系数据库,在优势上面也略高一筹:至于为什么会这么说呢?很简单,我们来举两个例子: 1.在存储上面,非关系型数据库可以更大规模的存储,打个比方,Facebook用的数据库就是非关系型数据库. 2.运用起来更加流畅也是这个数据库的优点,将分布式的特点发挥到极致. 当我查看官方文档的时候,简

  • Mongo DB增删改查命令

    1 列出并选用 1.1 列出所有数据库 > show dbs local 0.000GB myblog 0.000GB 1.2 使用某个数据库 > use myblog switched to db myblog 1.3 列出所有集合 > show collections articles replicationColletion sessions users wangduanduan 2 插入数据 insert(value) // 在已经存在的集合中插入数据 > db.users

随机推荐