node之crud学生信息管理系统之数据库(数据持久化)

本文介绍了一个使用Express和MongoDB实现的学生信息增删改查(CRUD)操作的示例。通过代码展示了如何设置路由处理各种HTTP请求,包括获取所有学生信息、添加新学生、编辑现有学生信息以及删除学生记录。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

代码基本不变,变化如下:
(上次代码参考我上篇博文)

这回开了三个控制台
一个打开数据库mongodb (mongd)
一个连接数据库 (mongo)
一个运行app.js (node app.js)
一:router.js的变化

// 路由模块
const express = require('express')
const Student = require('./student')
// 得到路由容器
const router = express.Router()
/*
  * 下面就是把每条路由都挂载到路由容器中
*/
// 请求'/',显示全部学生信息
router.get('/', (req, res) => {
  // 调用Student.find()API,获取所有学生信息
  Student.find((err, data) => {
    if (err) {
      return res.status(500).send('server error...')
    }
    let students = data // 得到全部学生信息数组
    res.render('index.html', {
      students: students,
      Labels: ['苹果', '香蕉', '橘子', '西瓜'],
      titles: ['id', 'name', 'age', 'hobbies', 'setting']
    })
  })
})


// 请求/add',显示添加学生信息的界面
router.get('/add', (req, res) => {
  res.render('add.html')
})


// 表单post提交数据到'/add',处理数据后重定向至'/'
router.post('/add', (req, res) => {
  /*
    *获取表单提交的数据
    *添加到数据文件中
    *重定向至首页,显示新提交的学生信息
  */
  
  new Student(req.body).save( (err) => {
    if (err) {
      return res.status(500).send('server error...')
    }
    res.redirect('/')
  })
})
// 请求'/edit',展示编译学生信息界面
router.get('/edit', (req, res) => {
  let id = req.query.id
  Student.findById(id, (err, student) => {
    if (err) {
      return res.status(500).send('server error...')
    }
    res.render('edit.html', {
      student: student
    })
  })
})


// 获取post请求提交的数据,更新学生信息,重定向到'/'
router.post('/edit', (req, res) => {
  /**
   * 获取新修改的post请求提交的学生信息
   * 处理数据文件,修改学生信息
   * 重定向到'/'
   */
  var id = req.body.id
  Student.findByIdAndUpdate(id,req.body, (err) => {
    if (err) {
      return res.status(500).send('server error...')
    }
    res.redirect('/')
  })
})
// 当请求'/delete',根据id值删除相应的学生信息,重定向到'/'
router.get('/delete', (req, res) => {
  let id = req.query.id
  Student.findByIdAndRemove(id, (err) => {
    if (err) {
      return res.status(500).send('server error...')
    }
    res.redirect('/')
  })
})


module.exports = router

二:student.js的变化(重要)

引入moogoose,运用mongoose

var mongoose = require('mongoose')

mongoose.connect('mongodb://localhost/text')

var Schema = mongoose.Schema
var studnetSchema = new Schema({   
 name:{       
  type:String,   
  require:true    },
gender:{        
type:Number,        
enum:[0,1],        
default:0    },    
age:{       
 type:Number    },    
 hobbies:{       
  type:String  
    }
    })

module.exports = mongoose.model('student',studnetSchema)

三:index.html变化

id那里,将$value.id改成$index+1

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值