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 balancer的使用详解
Apr 30 MongoDB
MongoDB数据库的安装步骤
Jun 18 MongoDB
MongoDB安装使用并实现Python操作数据库
Jun 28 MongoDB
常用的MongoDB查询语句的示例代码
Jul 25 MongoDB
SpringBoot 整合mongoDB并自定义连接池的示例代码
Feb 28 MongoDB
MongoDB数据库部署环境准备及使用介绍
Mar 21 MongoDB
mongoDB数据库索引快速入门指南
Mar 23 MongoDB
MongoDB数据库之添删改查
Apr 26 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 chr() ord()中文截取乱码问题解决方法
2008/09/08 PHP
apache和php之间协同工作的配置经验分享
2013/04/08 PHP
PHP中ob_start函数的使用说明
2013/11/11 PHP
php开发中的页面跳转方法总结
2015/04/26 PHP
php简单备份与还原MySql的方法
2016/05/09 PHP
Javascript 获取滚动条位置等信息的函数
2009/09/08 Javascript
jQuery下通过$.browser来判断浏览器.
2011/04/05 Javascript
真正的JQuery.ajax传递中文参数的解决方法
2011/05/28 Javascript
jquery实现的导航固定效果
2014/04/28 Javascript
jquery插件validation实现验证身份证号等
2015/06/04 Javascript
AngularJS自动表单验证
2016/02/01 Javascript
浅析JSONP技术原理及实现
2016/06/08 Javascript
JS+CSS3实现超炫的散列画廊特效
2016/07/16 Javascript
jquery获取点击控件的绝对位置简单实例
2016/10/13 Javascript
JS制作类似选项卡切换的年历
2016/12/03 Javascript
JavaScript基于Dom操作实现查找、修改HTML元素的内容及属性的方法
2017/01/20 Javascript
前端编码规范(3)JavaScript 开发规范
2017/01/21 Javascript
详细介绍RxJS在Angular中的应用
2017/09/23 Javascript
vue通过点击事件读取音频文件的方法
2018/05/30 Javascript
JS实现图片旋转动画效果封装与使用示例
2018/07/09 Javascript
一文了解Vue中的nextTick
2019/05/06 Javascript
为vue项目自动设置请求状态的配置方法
2019/06/09 Javascript
node.js 如何监视文件变化
2020/09/01 Javascript
Python中django学习心得
2017/12/06 Python
Python实现连接MySql数据库及增删改查操作详解
2019/04/16 Python
Python操作SQLite/MySQL/LMDB数据库的方法
2019/11/07 Python
HTML5学习笔记之html5与传统html区别
2016/01/06 HTML / CSS
关于h5中的fetch方法解读(小结)
2017/11/15 HTML / CSS
亚马逊墨西哥站:Amazon.com.mx
2018/08/26 全球购物
传统软件工程与面向对象的软件工程有什么区别
2012/05/31 面试题
哈理工毕业生的求职信
2013/12/22 职场文书
出国留学计划书
2014/04/27 职场文书
环保建议书400字
2014/05/14 职场文书
合作协议书模板
2014/10/10 职场文书
投资入股合作协议书
2014/10/28 职场文书
劳动合同变更协议书范本
2019/04/18 职场文书