MongoDB笔记---路遇超多坑

这篇博客记录了在Mac上安装MongoDB时需要关闭SIP,以及使用MongoDB过程中涉及的基本步骤,如数据库连接、集合创建、数据导入、查询、删除、更新等操作。同时,介绍了Mongoose文档验证和添加数据库账号的方法,最后提到了将MongoDB配置到环境变量的重要性。
摘要由CSDN通过智能技术生成

MongoDB笔记—路遇超多坑

Mac安装MongoDB时需要关闭本机SIP

  • 终端执行
csrutil status ---检查SIP是否开启   System.....:enabled  开启状态
  • 当文件再只读文件下时:获取操作权限
csrutil disable ---检查SIP是否开启  successfully....  	关闭状态
sudo mount -uw /
killall Finder

使用MongoDB的基本步骤

  • 连接数据库
//引入mongoose第三方模块,用来操作数据库
const mongoose = require('mongoose')
//数据库连接
mongoose.connect('mongodb://localhost/playground', { useNewUrlParser: true, useUnifiedTopology: true })
    //连接成功
    .then(() => {
        console.log('数据库连接成功');
        //连接失败
    })
  	.catch(err => {
        console.log(err, '数据库连接失败');
    })
  • 创建集合规则
//创建集合规则
const courseSchema = new mongoose.Schema({
    name: String,
    author: String,
    isPublished: Boolean
})
  • 使用规则创建集合
//使用规则创建集合
//mongoose.model(参数1:集合名词,参数2:集合规则(也就是Schema一个实例对象))
const Course = mongoose.model('Course', courseSchema)
const course = new Course({
    name: '第一个数据库',
    author: 'monkey',
    isPublished: true,
})
  • 保存数据库
//保存数据库
course.save()

导入外部数据库

  • 导入数据库数据
mongoimport -d 数据库名字  -c 集合名称 --file 要导入
mongoimport -d playground -c users --file ./user.json

使用数据库(操作数据库)

  • 查询文档

1. find方法

// 查询所有用户文档
User.find().then(result => console.log(result));
// 查询部分用户文档 find方法 用{_id:'id值'}
User.find({ _id: '5c09f1e5aeb04b22f8460965' }).then(result =>console.log(result));

2.findOne方法

//查询部分用户文档 findOne方法 用{name:''}
User.findOne({ name: '王二麻子' }).then(result => console.log(result))

3. 匹配大小

(>) 大于 - $gt
(<) 小于 - $lt
(>=) 大于等于 - $gte
(<= ) 小于等于 - $lte

4.包含匹配

//使用方式
User.find({ age: { $gt: 20, $lt: 40 } }).then(result => console.log(result))
//匹配包含
User.find({ hobbies: { $in: ['足球'] } }).then(result => console.log(result))

5. 匹配查询字段 (查询字段之间用空格隔开,不想要查询的字段前加-

					//select('想要查询的字段 <用空格隔开多个>  不想要查询的字段前加 ‘-’ +不想查询的字段')
User.find().select('name email -_id').then(result => console.log(result))
	User.find().select('name email -_id').then(result => console.log(result))

6. 将数据按照升降序进行排序

//两种语法
User.find().sort({ 'age': 1 }).then(result => console.log(result))
User.find().sort('-age').then(result => console.log(result))
//skip跳过当前多少条数据,limit限制查询数据
User.find().skip(2).limit(2).then(result => console.log(result))
  • 删除文档
    1. findOneAndDelete()方法
//查找到一条文档并删除
//返回删除的文档
User.findOneAndDelete({ _id: '5c09f2d9aeb04b22f846096b' }).then(result => console.log(result))

2. deleteMany()方法

//删除多个文档
//返回一个对象 n:表示个数   OK:表示成功  deletedCount:删除个数{ n: 5, ok: 1, deletedCount: 5 }
User.deleteMany({}).then(result => console.log(result))
  • 更新文档
    1.updateOne()方法
//updateOne({查询条件},{要修改的值})
User.updateOne({ name: '李四', }, { name: '李狗蛋' }).then(result => console.log(result))

2.updateMany()方法

//updateMany({查询条件},{要修改的值})
User.updateOne({}, { age: 22 }).then(result => console.log(result))

Mongoose文档验证

  • 验证文档
const postSchema = new mongoose.Schema({
    title: {
        //标题类型
        type: String,
        //必须字段(必须填写)
        required: true,
        //最小字段
        minlength: 2,
        //最大字段
        maxlength: 5,
        //去除字符串两边空格
        trim: true
    },
  	age: {
        type: Number,
        //数值最小值
        min: 18,
        //数值的最大值
        max: 100,
    },
    publicDate: {
        type: Date,
        //default:默认值
        default: Date.now
    },
  	category: {
        type: String,
        //文档中可以拥有的字段
        enum: ['html', 'javaScript', 'javascript', 'css']
    },
  	validate:{
      validator:v=>{
        return v && v.length > 4
      },
      message:'传入的值不符合验证规则'
    }
})
  • 控制台输出错误信息
Post.create({ title: '新闻直播间', age: 20, category: 'css', author: 'pesis' })
    .then(result => console.log(result))
    .catch(error => {
        const err = error.errors;
        for (attr in err) {
            console.log(err[attr]['message']);
        }
    })

为数据库添加账号

  • 连接数据库
//终端输入
mongo
  • 查看数据库
//终端输入
show dbs
  • 进入admin数据库,只有进入了admin数据库才可以创建超级管理员账号
 //终端输入
use admin
  • 创建超级管理员账号
//终端输入
db.createUser()
//实例
db.createUser({user:'monkey',pwd:'HJS19971203',roles:['root']})
  • 切换数据库
//终端输入
use ×××(自己存在的数据库)
  • 创建普通管理员账号
//终端输入
db.createUser()

补充

将MongoDB添加到环境变量

<添加环境变量>
vim ~/.bash_profile
<添加环境变量格式>export PATH=${PATH}:<PATH 1>
例子:
	export JAVA_HOME = /home/myuser/jdk1.7.0_03
	export PATH = $JAVA_HOME/bin:$PATH
<重新载入配置文件>
source <相应文件配置文件>
source .bash_profile
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值