Node学习笔记 优化crud增删改查

本篇文章结合前文《Node学习笔记 Mongodb和Mongoose》对 curd 示例 进行优化

MongoDB 安装

安装文件下载地址:[https://www.mongodb.com/download-center/community]

Windows 平台安装 MongoDB:https://www.runoob.com/mongodb/mongodb-window-install.html

在安装过程中需要特别注意,需要将 Install MongoDB Compass 前默认的勾选取消

可以使用 mongod --version 命令查看 MongoDB 版本,若版本号输出正常则安装完毕

Mongoose 安装和配置

npm install mongoose

优化 student.js 文件

有了 Mongoose 的帮助可以极大的简化数据的增、删、改、查工作

  • 首先,配置 Mongoose

    var mongoose = require('mongoose'); // 引入 mongoose
    mongoose.connect('mongodb://localhost/test'); // 通过 mongoose 连接 mongodb 数据库
    
  • 其次,设计 Schema 数据结构

    var mongoose = require('mongoose'); // 引入 mongoose
    mongoose.connect('mongodb://localhost/test'); // 通过 mongoose 连接 mongodb 数据库
    
    // 设计数据结构
    var Schema = mongoose.Schema
    var studentData = new Schema({ // 实例化 Schema
        name: { // 姓名
            type: String, // 数据类型 String
            required: true // 数据为必填项
        },
        gender: { // 性别
            type: Number, // 数据类型 Number
            default: 0, // 数据默认值
            enum: [0, 1] // 可枚举数据
        },
        age: { // 年龄
            type: Number // 数据类型 Number
        },
    })
    
  • 最后,导出 Student

    module.exports= mongoose.model('Student', studentData)
    // 将数据保存 Mongodb 数据库 Student 集合中
    // 导出 Mongodb 数据
    

到此为止,student.js 优化完毕

优化 router.js 文件

对于 router.js 文件,我们只需要调用 mongoose 提供的增、删、改、查 API 既可

代码如下:

var Student = require('./student') // 引入 student.js (student 模块专职用于处理数据)

var express = require('express') // 引入 express
var router = express.Router() // 创建路由容器

// 将所有路由都挂在到 router 路由容器中
router.get('/', function (req, res) { // 渲染学生列表页面
	// .find() 用于从数据库中查询所有数据,接收一个函数参数
    // function (err, students) 接收两个参数,其一为错误信息,二为查询的数据 students
    Student.find(function (err, students) {
        if (err) { // 若路由跳转错误,则抛出 Server error,状态码 500
            return res.status(500).send('Server error.')
        }
        res.render('index.html', { // 响应返回学生列表页面
            students: students
        })
    })
})

router.get('/new', function (req, res) { // 渲染添加学生页面
    res.render('new.html')
})

router.post('/new', function (req, res) { // 处理添加学生
    // new Student(req.body) 新建一条数据
    // .save 用于将数据添加到数据库,接收一个函数参数
    // function (err) 参数用于接收错误信息
    new Student(req.body).save(function (err) {
        if (err) { // 若路由跳转错误,则抛出 Server error,状态码 500
            return res.status(500).send('Server error.')
        }
        res.redirect('/') // 页面重定向回首页
    })
})

router.get('/edit', function (req, res) { // 渲染编辑学生页面
    // .findById() 用于根据 id 查询一条数据,接收两个参数,其一为匹配数据,二为函数
    // function (err, student) 函数接收两个参数,其一为错误信息,二为查询数据结果
    // req.query.id.replace(/"/g, '') 为需查询的数据 id ,通过 .replace 将 id 字符串转化为数字类型
    Student.findById(req.query.id.replace(/"/g, ''), function (err, student) {
        if (err) { // 若路由跳转错误,则抛出 Server error,状态码 500
            return res.status(500).send('Server error.')
        }
        res.render('edit.html', { // 响应返回编辑学生页面
            student: student
        })
    })
})

router.post('/edit', function (req, res) { // 处理编辑学生
    // .findByIdAndUpdate() 用于根据 id 更新数据,接收三个参数,其一为匹配数据,二为需替换的数据,三为函数
    // function (err) 函数接收错误信息
    // req.body.id.replace(/"/g, '') 为需查询的数据 id ,通过 .replace 将 id 字符串转化为数字类型
    var id = req.body.id.replace(/"/g, '')
    Student.findByIdAndUpdate(id, req.body, function (err) {
        if (err) { // 若路由跳转错误,则抛出 Server error,状态码 500
            return res.status(500).send('Server error.')
        }
        res.redirect('/') // 页面重定向回首页
    })
})

router.get('/students/delete', function (req, res) { // 处理删除学生
    // .findByIdAndRemove() 用于根据 id 删除对应数据,接收两个参数,其一为匹配数据,二为函数
    // function (err) 函数接收错误信息
    // req.body.id.replace(/"/g, '') 为需查询的数据 id ,通过 .replace 将 id 字符串转化为数字类型
    var id = req.query.id.replace(/"/g, '')
    Student.findByIdAndRemove(id, function (err) {
        if (err) { // 若路由跳转错误,则抛出 Server error,状态码 500
            return res.status(500).send('Server error.')
        }
        res.redirect('/') // 页面重定向回首页
    })
})

module.exports = router // 导出 router

文章已同步我的个人博客:《Node学习笔记 优化crud增删改查


资料参考:

本文由博客一文多发平台 OpenWrite 发布!

发布了16 篇原创文章 · 获赞 0 · 访问量 511

猜你喜欢

转载自blog.csdn.net/sz861128/article/details/103605034