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: '张三' });
相关推荐
布局呆星5 分钟前
SQLite数据库的介绍与使用
数据库·python
2401_838472516 分钟前
用Python和Twilio构建短信通知系统
jvm·数据库·python
石头wang11 分钟前
oracle jdbc 依赖以及对dbeaver的性能影响,如何选择oracle驱动, oracle jdbc 驱动
数据库·oracle
weixin_4521595513 分钟前
如何从Python初学者进阶为专家?
jvm·数据库·python
2301_7903009642 分钟前
用Python读取和处理NASA公开API数据
jvm·数据库·python
万象.1 小时前
redis持久化:AOF和RDB
数据库·redis·缓存
tod1131 小时前
力扣高频 SQL 50 题阶段总结(四)
开发语言·数据库·sql·算法·leetcode
!chen2 小时前
Redis快速实现布隆过滤器
数据库·redis·缓存
2301_790300962 小时前
数据分析与科学计算
jvm·数据库·python
-XWB-2 小时前
【Oracle】Oracle诊断系列(2/6):锁问题与阻塞分析——解决“卡住”的会话
数据库·oracle