MongoDB连接数据库并创建数据等使用方法


Posted in MongoDB onNovember 27, 2021

1.mongodb官网

MongoDB: the application data platform | MongoDB

2.进入MongoDB官网下载MongoDB以及MongoDB compass 和Mongodb--database--tools

3.nodejs操作MongoDB数据库需要依赖nodejs的第三方包mongoose 

终端指令: npm install mongoose

4.

MongoDB连接数据库并创建数据等使用方法

 5.

以管理员身份运行PowerShell cd到文件所在目录 如果没有开启MongoDB的话 

使用net start mongodb 指令启动

MongoDB连接数据库并创建数据等使用方法

MongoDB连接数据库并创建数据等使用方法

 6.

//引入mongoose模块
const mongoose = require('mongoose');
// console.log(mongoose);
 
//todo 连接数据库
mongoose.connect('mongodb://localhost/test001')
    .then(() => console.log('数据库链接成功'))
    .catch(erro => console.log('连接失败'))

7.在vscode的集成终端中cd到文件所在目录,使用nodemon 'node 02.js'指令打开文件

MongoDB连接数据库并创建数据等使用方法

 8. 设定集合规则 创建集合并应用规则

//todo 设定集合规则
const courseSchema = new mongoose.Schema({
    name: String,
    author: String,
    isPublished: Boolean
});
// todo 创建集合并应用规则
// todo 1.集合名称'' 2.集合规则
const Course = mongoose.model('Course', courseSchema);

  9. 创建集合实例document的两种方式

// todo 第一种方式   创建集合实例 文档document
const course = new Course({
    name:'xiaoguo',
    author:'aaa',
    tags:['node','backend'],
    isPublished:false
})
// 将数据保存在数据库中
course.save();
 
 
 
//todo 第二种方式 创建文档 不需要使用course.save()方式保存,会自动保存进数据库
Course.create({
    name:'xiaowei',
    author:'sh',
    isPublished:true
},(erro,data)=>{
    console.log(erro);
    console.log(data)
});
//也支持promise对象
Course.create({
    name:'xiaoli',
    author:'zz',
    isPublished:true
}).then(data=> console.log(data))
.catch(erro=>console.log(erro))

 10. 查询用户集合中的所有文档,返回的是一个数组

// todo 查询用户集合中的所有文档 返回的是一个数组
Course.find()
.then(result =>{console.log(result)})

 11. 通过ID字段查询用户集合中的某个文档,返回数组

// todo 通过ID字段查询用户集合中的某个文档 返回数组
Course.find({
_id:"619b0f75dc5e07d1b9924ee9"
})
.then(result =>{console.log(result)})

 12. 根据条件查找文档 如果不写条件返回数据库中的第一条文档 返回一个对象

// todo 根据条件查找文档 如果不写条件返回数据库中的第一条文档 返回一个对象
Course.findOne({
    name:'xiaowei'
})
.then(result=>console.log(result))

13. 根据范围条件查找文档 $gt 最小值 $lt最大值

// todo 根据范围条件查找文档
Course.find({
    age: { $gt: 20, $lt: 50 }
})
.then(result => console.log(result))

 14. 查询包含

// todo 根据范围条件查找文档
Course.find({
    name: { $in: ['xiao'] }
})
.then(result => console.log(result))

 15. 选择要查询的字段并排序 默认升序 降序加个-

// todo 选择要查询的字段 (升序)
Course.find().select('name age')
//相反的顺序用.sort('-age') (降序)
.then(result => console.log(result))

  16.  skip跳过前两条数据 limit限制查询数量

// todo skip跳过前两条数据 limit限制查询数量
Course.find().skip(2).limit(2)
.then(result => console.log(result))

   17.  查找一个文档并删除文档 返回值是删除的文档 如果匹配到多个文档 只删除第一个

// todo 查找一个文档并删除文档 返回值是删除的文档 如果匹配到多个文档 只删除第一个
Course.findOneAndDelete({
   _id:"619b0f75dc5e07d1b9924ee9"
})
.then(result=>console.log(result))

 18.  删除多个文档  返回一个对象 {n:删除的文档数量 ok:1(删除成功)}

// todo 删除多个文档  返回一个对象 {n:删除的文档数量 ok:1(删除成功)}
Course.deleteMany({
   _id:"619b0f75dc5e07d1b9924ee9"
})
.then(result=>console.log(result))

  19.  更新单个文档 里面传两个对象 ,隔开 第一个对象是查询条件 第二个要改的值

// todo 更新单个文档 里面传两个对象 ,隔开 第一个对象是查询条件 第二个要改的值
Course.updateOne(
{name:'xiaoguo'},
{name:'xiaoguoguo'}
)
.then(result=>console.log(result))

   20.  更新多个文档 里面传两个对象 ,隔开 第一个对象是查询条件 第二个要改的值

// todo 更新多个文档 里面传两个对象 ,隔开 第一个对象是查询条件 第二个要改的值
Course.updateMany(
{},
{age:18}
)
.then(result=>console.log(result))

    21. 设置mongoose验证

 针对String类型字段      required: [true,'错误说明']   必传字段  

MongoDB连接数据库并创建数据等使用方法

  针对String类型字段      minlength: [n,'错误说明']       最小字段长度

 针对String类型字段       maxlength: [n,'错误说明']      最大字段长度

MongoDB连接数据库并创建数据等使用方法

  针对String类型字段      trim:true       //去除字符串两头的空格

  针对Number类型字段      min: [n,'错误说明']       最小数值

 针对Number类型字段       max: [n,'错误说明']      最大数值

 设置时间默认值 当用户未传此字段的数据时 启用当前时间为默认值 

MongoDB连接数据库并创建数据等使用方法

 列举出当前字段可以取的值,必须在范围内上传

MongoDB连接数据库并创建数据等使用方法

 自定义错误信息时的格式

MongoDB连接数据库并创建数据等使用方法

制定规则验证用户传入的值的属性是否符合规范 自定义错误信息 message 

MongoDB连接数据库并创建数据等使用方法

 控制台获取错误信息

 MongoDB连接数据库并创建数据等使用方法

到此这篇关于MongoDB连接数据库并创建数据等使用方法的文章就介绍到这了,更多相关MongoDB连接数据库内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

MongoDB 相关文章推荐
MongoDB使用profile分析慢查询的步骤
Apr 30 MongoDB
MongoDB balancer的使用详解
Apr 30 MongoDB
SpringBoot整合MongoDB的实现步骤
Jun 23 MongoDB
浅析MongoDB之安全认证
Jun 26 MongoDB
centos8安装MongoDB的详细过程
Oct 24 MongoDB
MongoDB连接数据库并创建数据等使用方法
Nov 27 MongoDB
SpringBoot系列之MongoDB Aggregations用法详解
Feb 12 MongoDB
MongoDB使用场景总结
Feb 24 MongoDB
一次线上mongo慢查询问题排查处理记录
Mar 18 MongoDB
MongoDB支持的索引类型
Apr 11 MongoDB
springboot + mongodb 通过经纬度坐标匹配平面区域的方法
Nov 01 #MongoDB
centos8安装MongoDB的详细过程
关于CentOS 8 搭建MongoDB4.4分片集群的问题
MongoDB日志切割的三种方式总结
Sep 15 #MongoDB
mongodb清除连接和日志的正确方法分享
Sep 15 #MongoDB
阿里云服务器部署mongodb的详细过程
Sep 04 #MongoDB
mongodb数据库迁移变更的解决方案
Sep 04 #MongoDB
You might like
PHP中调用ASP.NET的WebService的代码
2011/04/22 PHP
使用phpQuery采集网页的方法
2013/11/13 PHP
PHP实现将优酷土豆腾讯视频html地址转换成flash swf地址的方法
2017/08/04 PHP
xml 封装与解析(javascript和C#中)
2009/07/26 Javascript
JavaScript对象之间的转换 jQuery对象和原声DOM
2011/03/07 Javascript
jquery中的mouseleave和mouseout的区别 模仿下拉框效果
2012/02/07 Javascript
借助script进行Http跨域请求:JSONP实现原理及代码
2013/03/19 Javascript
Jquery实现图片放大镜效果的思路及代码(自写)
2013/10/18 Javascript
仿百度联盟对联广告实现代码
2014/08/30 Javascript
Bootstrap每天必学之简单入门
2015/11/19 Javascript
jQuery操作cookie
2016/08/08 Javascript
详解获取jq ul第一个li定位的四种解决方案
2016/11/23 Javascript
jQuery Validate设置onkeyup验证的实例代码
2016/12/09 Javascript
ES6中箭头函数的定义与调用方式详解
2017/06/02 Javascript
JavaScript数据类型的存储方法详解
2017/08/25 Javascript
微信小程序支付及退款流程详解
2017/11/30 Javascript
详解html-webpack-plugin用法全解
2018/01/22 Javascript
jQuery与vue实现拖动验证码功能
2018/01/30 jQuery
一次记住JavaScript的6个正则表达式方法
2018/02/22 Javascript
jQuery实现input[type=file]多图预览上传删除等功能
2019/08/02 jQuery
序列化模块json代码实例详解
2020/03/03 Javascript
javascript实现随机抽奖功能
2020/12/30 Javascript
python如何把字符串类型list转换成list
2020/02/18 Python
python 如何使用find和find_all爬虫、找文本的实现
2020/10/16 Python
Web前端绘制0.5像素的几种方法
2017/08/11 HTML / CSS
html5 canvas 画图教程案例分析
2012/11/23 HTML / CSS
澳大利亚连衣裙和女装在线:Esther
2017/11/11 全球购物
Ray-Ban雷朋瑞典官方网站:全球领先的太阳眼镜品牌
2019/08/22 全球购物
最受欢迎的自我评价
2013/12/22 职场文书
运动会广播稿500字
2014/01/28 职场文书
会计专业应届生自荐信
2014/02/07 职场文书
数学系毕业生求职信
2014/05/29 职场文书
医生爱岗敬业演讲稿
2014/08/26 职场文书
靠谱准确的求职信
2019/04/02 职场文书
MySQL 使用索引扫描进行排序
2021/06/20 MySQL
SpringMVC 整合SSM框架详解
2021/08/30 Java/Android