Node.js-Mongodb数据库

MongoDB

MongoDB是什么?

MongoDB是一个基于分布式文件存储的数据库

数据库是什么?

数据库(DataBase)是按照数据结构来组织、存储和管理数据的应用程序(软件)

数据库作用?

对数据进行增、删、改、查

数据库特点?

  • 速度更快(一些数据库有特定的结构,可以加快访问)
  • 扩展性更强(多数据库节点)
  • 安全姓更强(加密)

为什么选Mongodb?

操作鱼js类似,容易上手,学习成本低

核心概念

Mongodb中有三个重要概念:

  • 数据库(database) 数据库是一个数据仓库,数据库服务下可以创建很多数据库,数据库中可以存放很多集合
  • 集合(collection) 集合类似于JS中的数组,在集合中可以存放很多文档
  • 文档(document)文档是数据库中最小单位,类似于JS中的对象

理解三者关系

  • db.json可以理解成一个数据库,一个数据库服务下可以创建N个数据库,它们之间不会共享任何数据。

  • json文件中的)属性(accountsusers)所对应的数组信息 ,就是集合 ,每个集合 存储着一类特定的数据,如accounts 集合存储了与账户相关的记录,而 users 集合则存储了用户的信息。

  • accounts这个集合中有很多对象,每一个对象就是一个文档(每个文档是一个独立的数据单元 ,包含多个键值对 ,每个文档中的键值对(例如 "id": "3-YLju5f3")是一个字段

    {
    "accounts": [
    {
    "id": "3-YLju5f3",
    "title": "买电脑",
    "time": "2023-02-08",
    "type": "-1",
    "account": "5500",
    "remarks": "为了上网课"
    },
    {
    "id": "3-YLju5f4",
    "title": "请女朋友吃饭",
    "time": "2023-02-08",
    "type": "-1",
    "account": "214",
    "remarks": "情人节聚餐"
    },

    复制代码
      {
        "id": "mRQiD4s3K",
        "title": "发工资",
        "time": "2023-02-19",
        "type": "1",
        "account": "4396",
        "remarks": "终于发工资啦!~~"
      }
    ],
    "users":[
      {
        "id": 1,
        "name": "zhangsan",
        "age": 18
      },
      {
        "id": 2,
        "name": "lisi",
        "age": 20
      },
      {
        "id": 3,
        "name": "wangwu",
        "age": 22
      }
    ]

    }

Mongodb服务

下载安装

Mongodb下载地址:https://www.mongodb.com/try/download/community,有msi和压缩包可以选,本次下载是采用压缩包形式。

从MongoDB 6.0开始,官方推荐使用MongoDB Shell (mongosh) 作为新的命令行工具,而不是传统的mongo.exe。

Mongosh下载地址:https://www.mongodb.com/try/download/shell?spm=5176.28103460.0.0.297c5d27VMftbK

Mongodb和Mongosh建议都解压在C盘下的Program Files中,并且在C盘文件中,创建data文件夹,再在data文件夹中创建db文件夹作为Mongodb的默认文件夹。

复制代码
// 启动服务
mongod
// or
mongod --dbpath "C:\data\db
// 启动 MongoDB Shell 并连接到 MongoDB 实例
mongosh

命令行交互

数据库命令
复制代码
// 显示所有的数据库
show dbs

// 切换指定数据库
use 数据库名

// 删除数据库
use 数据库名
db.dropDatabase()

// 创建集合
db.createCollection('集合名称')

// 显示当前数据库的集合
show collections

// 删除某个集合
db.库名.drop()

// 重命名集合
db.库名.renameCollection('newName')
文档命令
复制代码
// 插入文档/
db.集合名.insert(文档对象)

// 查询文档
db.集合名.find(查询条件)

// 更新文档
db.集合名.update(查询条件, 新文档)  
db.users.update({name: 'Bob'},{age: 18})

db.集合名.update({name:'Bob'},{$set:{age:19}})

// 删除文档
db.集合名.remove(查询条件)
//  remove() 方法已经被弃用
// 删除第一个匹配的文档
db.collection.deleteOne( { name: '张三' });

// 删除所有匹配的文档
db.collection.deleteMany( { name: '张三' });
相关推荐
安当加密4 小时前
MySQL 数据库如何加密脱敏?TDE透明加密 + DBG数据库网关 双引擎加固实战
数据库·mysql·adb
IT技术分享社区4 小时前
MySQL统计查询优化:内存临时表的正确打开方式
数据库·mysql·程序员
短剑重铸之日4 小时前
7天读懂MySQL|Day 5:执行引擎与SQL优化
java·数据库·sql·mysql·架构
好记忆不如烂笔头abc5 小时前
RECOVER STANDBY DATABASE FROM SERVICE xxx,ORA-19909
数据库
writeone5 小时前
数据库习题
数据库
廋到被风吹走6 小时前
【数据库】【Oracle】分析函数与窗口函数
数据库·oracle
佳佳_6 小时前
关于在 Fabric.js 中注册字体覆盖的问题
后端·node.js
陌北v17 小时前
为什么我从 MySQL 迁移到 PostgreSQL
数据库·mysql·postgresql
北辰水墨7 小时前
Protobuf:从入门到精通的学习笔记(含 3 个项目及避坑指南)
数据库·postgresql
JIngJaneIL7 小时前
基于java+ vue医院管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot