在Node中基于Mongoose对MongoDB进行增删查改(CRUD)操作(一)

本文介绍了在Node.js环境中使用Mongoose库进行MongoDB的CRUD操作,包括MongoDB、Mongoose和Robomongo的简介,安装过程,以及通过Mongoose创建、读取、更新和删除数据的基本步骤。同时,展示了数据库连接、模式定义、模型创建和实例化的过程。
摘要由CSDN通过智能技术生成

关键词:mongodb安装 mongoose使用 robomongo mongoose的CRUD操作 mongoose的查询,增加,修改,删除

工具介绍

MongoDB

MongoDB是基于Javascript语言的数据库,存储格式是JSON,而Node也是基于JavaScript的环境(库),所以node和mongoDB的搭配能减少因为数据转换带来的时间空间开销。

Mongoose

是MongoDB的一个对象模型工具,它将数据库中的数据转换为JavaScript对象以供你在应用中使用,封装了MongoDB对文档的的一些增删改查等常用方法,让NodeJS操作Mongodb数据库变得更加灵活简单。

Robomongo

一个可视化的mongoDB操作软件,类似于mysql的navicat可视化工具。

捋一捋它们的关系,mongoDB是一个数据库,mongoose是你在自己代码中操作mongo数据库的接口,而robomongo是mongo数据库的可视化工具,通过它的界面方便直接操作数据库内容。

工具安装

MongoDB安装

1.安装mongoDB

到官网https://www.mongodb.com/download-center#community下载程序安装,选择custom模式就行。

2.建立MongoDB环境

需要自己建立db目录作为数据库环境,在命令行窗口中输入

$ md \data\db

建立db文件夹后,在命令窗口中进入安装目录的bin文件夹执行mongod.exe,把数据库安装在\data\db中。mongoDB会检测你的根目录是否有data\db文件夹,如果有会默认安装到这个文件夹里面。

 $ cd C:\Program Files\MongoDB\Server\3.2\bin

 $ mongod.exe

当然也可以直接在系统根目录下创建data\db文件夹,然后在mongoDB安装文件夹中双击执行mongod.exe。

3.启动MongoDB

命令行工具中输入:

 $ cd C:\Program Files\MongoDB\Server\3.2\bin

 $ mongod.exe

为了避免每次都要输入目录,所以在系统变量里面配置一下path变量,把“;C:\Program Files\MongoDB\Server\3.2\bin”放到path后面(记得加;隔开),以后可以直接在命令行窗口输入mongod.exe回车即可。

在浏览器中输入网址:http://localhost:27017/ 。如果服务启动成功会看到以下一段话:It looks like you are trying to access MongoDB over HTTP on the native driver port.

4.连接MongoDB(这一步基本没有用,只有在命令行工具中使用mongo原生方法时需要,而在mongoose里面会有连接的代码,Robomongo运行也会有连接)

命令行工具中输入mongo.exe,回车。

如果出现这个警告:2016-07-16T14:49:02.827+0800 I CONTROL [main] Hotfix KB2731284 or later update is not installed, will zero-out data files那是因为Windows缺少一个补丁,从这个链接下周补丁451413_intl_x64_zip,然后解压安装包,在你解压的目录下找到Windows6.1-KB2731284-v3-x64.mus安装文件。安装重启即可。

Robomongo安装以及使用

直接到官网https://robomongo.org/下载安装,安装成功后运行,第一次运行,需要新创建一个连接,如图创建test,点击save保存连接。

这里写图片描述

选择test,点击connect连接数据库。robomongo会自己搜索你系统里面安装的mongodb并与其连接。如图

这里写图片描述

连接成功后,显示你的数据库,在这个节目可以对数据库进行操作。如图:

这里写图片描述

Mongoose安装与加载

首先假定你已经安装了 Node.js,命令行工具输入:

$ npm install mongoose -g

在使用的文件中require(“mongoose”);即可。

使用Mongoose进行CRUD操作

使用基本步骤

Mongose基于mongodb的原生方法,自己定义了一套操作MongoDB数据库的接口,比原生方法更加简单方便。为了更加直观,下面的步骤结合例子来讲。假如我需要做一个教务系统,需要存储学生Student的信息,学生信息通常包含姓名name,学号id,电话phone,登录日期date等。我把学生的信息存在mongodb的myDB数据库中,集合的名字叫students。如图:

这里写图片描述

_id这个域你可以自己定义,但如果你没有定义,系统会自动给你加上。下面先介绍在node中通过mongoose对mongodb进行操作的必须前提步骤:

1.node连接数据库

mongoose.connect('mongodb://user:pass@ip:port/database');

这只是最基本的连接,我们一般还会加一些设置,是否开启调试模式,连接提示等。通常我会这么写:

var mongoose = require("mongoose");
mongoose.Promise = global.Promise;

/*调试模式是mongoose提供的一个非常实用的功能,用于查看mongoose模块对mongodb操作的日志,一般开发时会打开此功能,以便更好的了解和优化对mongodb的操作。*/
mongoose.set('debug', true);

/*一般默认没有user和password*/
var db=mongoose.connect('mongodb://localhost/myDB');

db.connection.on("error", function (error) {
     
  console.log("数据库连接失败:" + error); 
}); 

db.connection.on(
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
1. 安装mongoose 在命令行执行以下命令: ``` npm install mongoose ``` 2. 连接数据库Node.js使用mongoose连接数据库需要先引入mongoose模块: ```javascript const mongoose = require('mongoose') ``` 接着使用mongoose.connect()方法连接数据库: ```javascript mongoose.connect('mongodb://localhost:27017/databaseName', { useNewUrlParser: true }) ``` 其mongodb://localhost:27017/databaseName是连接数据库的URL,其localhost为数据库服务器地址,27017为MongoDB的默认端口号,databaseName为要连接的数据库名称。 { useNewUrlParser: true }是Mongoose的一个选项,以允许在连接时使用新的URL字符串解析器。 3. 定义Schema和Model 在使用mongoose之前,需要先定义Schema和Model。Schema是用来定义数据结构的,Model是由Schema生成的实例。 ```javascript const Schema = mongoose.Schema const userSchema = new Schema({ username: String, password: String, email: String }) const User = mongoose.model('User', userSchema) ``` 以上代码定义了一个名为User的Model,该Model对应的Schema定义了三个属性:username、password和email。 4. CRUD操作 通过定义好的Model可以进行CRUD操作。以下是一些常用的操作: - 新增数据 ```javascript const user = new User({ username: 'Tom', password: '123456', email: 'tom@example.com' }) user.save(function (err, user) { if (err) return console.error(err) console.log(user.username + ' saved to database.') }) ``` - 查询数据 ```javascript User.find(function (err, users) { if (err) return console.error(err) console.log(users) }) ``` - 更新数据 ```javascript User.findOneAndUpdate({ username: 'Tom' }, { password: '654321' }, function (err, user) { if (err) return console.error(err) console.log(user) }) ``` - 删除数据 ```javascript User.deleteOne({ username: 'Tom' }, function (err) { if (err) return console.error(err) console.log('User deleted.') }) ``` 以上代码演示了如何使用mongoose连接MongoDB数据库,并进行CRUD操作
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值