博客
关于我
3.2 mongoose 增删改查-案例2
阅读量:724 次
发布时间:2019-03-21

本文共 2642 字,大约阅读时间需要 8 分钟。

mongoose 操作(增删改查)案例详解

1. 用户管理表操作

1.1 查询数据

使用mongoose查询用户数据:

const mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/dadi', { useNewUrlParser: true, useUnifiedTopology: true });
const UserSchema = mongoose.Schema({
name: String,
age: Number,
status: Number
});
const User = mongoose.model('User', UserSchema);
// 查询所有用户数据
User.find({}, function(err, docs) {
if (err) {
console.log('查询失败:', err);
} else {
console.log('查询成功:', docs);
}
});

1.2 增加用户数据

新增用户信息:

const user = new User({
name: '张三',
age: 30,
status: 1
});
user.save((err, result) => {
if (err) {
console.error('用户数据存储失败:', err);
} else {
console.log('用户数据已成功存储:', result);
}
});

1.3 更新用户信息

更新特定用户信息:

User.updateOne({ _id: '5f3c002c-aPARTa-XXXX-XXXX-XXXX-XXXXX' }, {
name: '张三 updated',
age: 35
}, (err, result) => {
if (err) {
console.error('更新失败:', err);
} else {
console.log('用户信息更新成功:', result);
}
});

1.4 删除用户信息

删除特定用户:

User.deleteOne({ _id: '5f3c002c-aPARTa-XXXX-XXXX-XXXX-XXXXX' }, function(err, result) {
if (err) {
console.error('删除失败:', err);
} else {
console.log('用户数据已删除:', result);
}
});

2. 新闻管理表操作

2.1 创建新闻表

首次操作新闻表(需要手动创建集合):

const mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/dadi', { useNewUrlParser: true, useUnifiedTopology: true });
const NewsSchema = mongoose.Schema({
title: String,
author: String,
pic: String,
status: Number
});
const News = mongoose.model('News', NewsSchema, 'news'); // 第三个参数指定集合名

2.2 新增新闻数据

新增一条新闻:

const news = new News({
title: '第一条新闻',
author: '管理员',
pic: 'news1.jpg',
status: 1
});
news.save((err, result) => {
if (err) {
console.error('新闻数据存储失败:', err);
} else {
console.log('新闻数据已成功存储:', result);
}
});

2.3 查询新闻数据

查询所有新闻:

News.find({}, (err, newsList) => {
if (err) {
console.log('查询失败:', err);
} else {
console.log('新闻列表:', newsList);
}
});

2.4 更新新闻内容

更新特定新闻:

News.updateOne({ _id: '5f3c002c-aPARTb-XXXX-XXXX-XXXX-XXXXX' }, {
title: '重要消息更新',
author: '管理员 updated'
}, (err, result) => {
if (err) {
console.error('更新失败:', err);
} else {
console.log('新闻信息更新成功:', result);
}
});

2.5 删除新闻数据

删除特定新闻:

News.deleteOne({ _id: '5f3c002c-aPARTb-XXXX-XXXX-XXXX-XXXXX' }, (err, result) => {
if (err) {
console.error('删除失败:', err);
} else {
console.log('新闻数据已删除:', result);
}
});

注意事项

  • 确保数据库服务器正常运行,并且权限设置正确。
  • 运行以上实验前,请自行创建相应的数据库和集合,避免操作异常。
  • 对于大数据量操作,建议提升数据库性能,并根据实际需求优化查询方式。
  • 注意在开发过程中遵守相关数据库管理规范,确保数据安全和系统稳定。
  • 转载地址:http://jqbgz.baihongyu.com/

    你可能感兴趣的文章
    Node-RED中使用JSON数据建立web网站
    查看>>
    Node-RED中使用json节点解析JSON数据
    查看>>
    Node-RED中使用node-random节点来实现随机数在折线图中显示
    查看>>
    Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
    查看>>
    Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
    查看>>
    Node-RED中实现HTML表单提交和获取提交的内容
    查看>>
    Node.js 函数是什么样的?
    查看>>
    Node.js 实现类似于.php,.jsp的服务器页面技术,自动路由
    查看>>
    node.js 怎么新建一个站点端口
    查看>>
    Node.js 文件系统的各种用法和常见场景
    查看>>
    node.js 简易聊天室
    查看>>
    node.js 配置首页打开页面
    查看>>
    node.js+react写的一个登录注册 demo测试
    查看>>
    Node.js中环境变量process.env详解
    查看>>
    Node.js安装与配置指南:轻松启航您的JavaScript服务器之旅
    查看>>
    Node.js安装和入门 - 2行代码让你能够启动一个Server
    查看>>
    Node.js的循环与异步问题
    查看>>
    NodeJS @kubernetes/client-node连接到kubernetes集群的方法
    查看>>
    Nodejs express 获取url参数,post参数的三种方式
    查看>>
    nodejs libararies
    查看>>