MongoDB 非关系型数据库

汪鸿志
2023-12-01

一、起步

  • MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。
  • MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。

二、安装MongoDB

  • 官网下载地址并安装
  • 配置安装目录下的bin到环境变量中去
  • 如需进行测试可以使用:
mongod -v

三、打开mongodb数据库

  • 在键入mongod命令前需要改对应盘符的根目录下创建data/db目录
  • 然后键入命令
D:\> mongod
  • 保持shell的打开状态

四、连接mongodb数据库

  • 保持mongodb数据库打开状态
  • 在命令行中输入
D:\> mongo

五、常用的命令

  • 显示mongodb中所有数据库
show dbs
  • 显示当前数据库
db
  • 切换或创建新数据库
use 数据库名
  • 显示当前数据库的所有集合名
show collections
  • 显示当前数据库指定集合的所有文档
db.集合名.find()

六、Node.js中操作MongoDB

1、使用MongoDB官方的node-mongodb-native

官方文档

2.使用Mongoose模块

中文文档

2.1 安装Mongoose

npm i mongoose

2.2 连接MongoDB

const mongoose = require('mongoose')

mongoose.connect('mongodb://localhost/数据库名',{useNewUrlParser: true})

2.3 设计数据库表(集合)

Schema就是一个模板,起到了预先设计数据表的作用。其中required属性为真代表了改字段不可为空

const UserSchema = new mongoose.Schema({
    name:{
        type: String,
        required: true
    },
    passworld:{
        type: String,
        required: true
    },
    email:{
        type:String
    }
})

2.4 增加文档

mongoose.model中的第一个参数为表名,也就是集合名,第二个参数是设计好的表结构。
插入一条name为admin的文档

const User = mongoose.model('User',UserSchema) // 相当于User表集合

let Admin = new User({     //单文档
    name:"admin",
    passworld:"123123"
    email:"123@qq.com"
})

Admin.save().than(()=>{      //Promise
    console.log("success!")
},()=>{
    console.log("error")
})

2.5 查找文档

方法参数功能
find[{属性:值[,…]}],(err,data)=>{}查找满足指定属性=值的文档数组到回调中data,第一个参数省略为无条件查找
findOne[{属性:值[,…]}],(err,data)=>{}查找满足指定属性=值的第一条文档到回调中data,第一个参数省略为无条件查找

例如

cat.find({
    name: "milse88"
},(err,cats)=>{
    if(err){
        throw err
    }
    console.log(cats)
})

cat.findOne((err,data)=>{
    if(err){
        throw err
    }
    console.log(data)
})

结果为:

[ { _id: 5d2be43e1fb7af12f0f745a8, name: 'milse88', __v: 0 } ] #数组
{ _id: 5d2be315679a272f2459966c, name: 'milse', __v: 0 }       #对象

2.6 删除文档

方法参数功能
deleteOne[{属性:值[,…]}],(err,res)=>{}查找满足指定属性=值的第一个文档进行删除,第一个参数省略为无条件删除
deleteMany[{属性:值[,…]}],(err,res)=>{}查找满足指定属性=值的所有文档进行删除,第一个参数省略为无条件查找
remove[{属性:值[,…]}],(err,res)=>{}查找满足指定属性=值的所有文档进行删除,第一个参数省略为无条件查找 (官方文档中说明改方法以不建议使用),因此不再举例
  • 注意,Moogoose使用正则匹配,所以条件对象中的值可以为正则表达式的形式出现
  • Model.AIP的回调都是以(error,result)=>{}的方式出现

例如:

cat.deleteOne({
    name:"milse8"
},(err,res)=>{
    if(err)throw err
    console.log('删除成功!')
    console.log(res)
})

cat.deleteMany({
    name:/milse8/m
},(err,res)=>{
    if(err) throw err
    console.log('删除成功!')
    console.log(res)
})

结果:

删除成功!
{ n: 1, ok: 1, deletedCount: 1 }
删除成功!
{ n: 10, ok: 1, deletedCount: 10 }

2.7 更新文档

方法参数功能
updateOne[{属性:值[,…]}],{属性:值[,…]},(err,res)=>{}第一个参数为条件对象,第二个参数为更新对象,找到第一个满足条件的文档,按更新对象进行更新
updateMany[{属性:值[,…]}],{属性:值[,…]},(err,res)=>{}找到所有满足条件的文档,按更新对象进行更新,如第一个条件缺省,则更新数据库中的所有文档

例如

cat.updateOne({
    name: 'milse1'
},{
    name: 'maojiankai'
},(err,res)=>{
    console.log(res)
})

cat.updateMany({
    name: /milse1/m
},{
    name: 'maojiankai'
},(err,res)=>{
    console.log(res)
})

结果

{ n: 1, nModified: 1, ok: 1 }
{ n: 10, nModified: 10, ok: 1 }

2.8 设置全局属性

mongoose中提供了设置全局属性的方法,这将运用到含有该属性的方法中去

mongoose.set('属性名',值)

例如,我们可以将原来的连接数据库方式改为

//原来
mongoose.connect('mongoose://localhost/数据库名',{'useNewUrlParser': true})

//改为 :
mongoose.set('useNewUrlParser',true)
mongoose.connect('mongoose://localhost/数据库名')
  • 注:MongoDB Node.js驱动程序重写了用于解析MongoDB连接字符串的工具。因为这是一个很大的变化,所以他们将新的连接字符串解析器放在一个标志后面。要打开此选项, 请将useNewUrlParser选项传递给 mongoose.connect()mongoose.createConnection()
 类似资料: