Sequelize入门及简单的增删改查

2024-06-23 18:28

本文主要是介绍Sequelize入门及简单的增删改查,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

学习一下NodeJS怎么使用Sequelize怎么查询数据库数据


一、Sequelize是什么?

Sequelize 是一个基于 promise 的 Node.js ORM,

二、搭建项目

1.安装过程

npm i -g  sequelize-cli //全局安装sequelize-clinpm i  sequelize mysql2  //安装sequelize和mysql2sequelize init  //初始化模型

初始化成功之后会自动生成这四个文件夹 

 

2.配置数据库信息,修改生成的文件夹之中的config\config.json

3.创建表

sequelize model:generate --name Article --attributes title:string,content:text
//Article :表名
//title,content:表内容
//string,text:表内容类型

执行成功之后如下且会在这两个文件夹中生成这两个js

 

4.向数据库创建表

sequelize db:migrate

Navicat中就会创建这两个表 

 

5.通过种子文件大量新增数据 

sequelize seed:generate  --name article//article:表名

运行成功之后将会在seeders文件中生成这个命名格式的js文件 

 在这个文件中编写新增数据的代码

'use strict';/** @type {import('sequelize-cli').Migration} */
module.exports = {async up(queryInterface, Sequelize) {const articles = []const counts = 100for (let i = 1; i <= counts; i++) {//表内的相关字段 const article = {title: `文章标题${i}`,content: `文章内容${i}`,createdAt: new Date(),updatedAt: new Date()}articles.push(article)}await queryInterface.bulkInsert('Articles',articles,{});},async down(queryInterface, Sequelize) {/*** Add commands to revert seed here.** Example:* await queryInterface.bulkDelete('People', null, {});*/await queryInterface.bulkDelete('Articles', null, {});}
};
sequelize db:seed  --seed 20240619135935-article//20240619135935-article:这个时seeders新增的js文件名

 运行之后可在Navicat中查看新增的数据

三.sequelize增删改查

在routes文件夹中创建一个文件夹,可自行命名,我命名为admin,并且在admin文件夹中新增一个articles.js

var express = require('express');
var router = express.Router();
const { Article } = require('../../models');module.exports = router;

在根目录中的app.js中新增

var adminRouter = require('./routes/admin/articles');app.use('/admin/articles', adminRouter);

1.新增 

articles.js

router.post('/', async function (req, res, next) {try {const article = await Article.create(req.body)res.status(200).json({code: 200,message: "新增成功",data: article})}catch (error) {res.status(500).json({code: 500,message: "新增失败",errors: [error.message]})}
})

2.删除

router.delete('/:id', async function (req, res, next) {try {const { id } = req.paramsconst article = await Article.findByPk(id)if (article) {await article.destroy()res.json({status:true,message:"删除成功"})} else {res.status(404).json({code: 404,message: "查询不到信息"})}}catch (error) {res.status(500).json({code: 500,message: "删除失败",errors: [error.message]})}
})

3.更新

router.put('/:id', async function (req, res, next) {try {const { id } = req.paramsconst article = await Article.findByPk(id)if (article) {await article.update(req.body)res.json({status:true,message:"更新成功",data:article})} else {res.status(404).json({code: 404,message: "查询不到信息"})}}catch (error) {res.status(500).json({code: 500,message: "删除失败",errors: [error.message]})}
})

4.查看所有内容(带有模糊查询)

router.get('/', async function (req, res, next) {try {const query =req.queryconst condition = {order: [['id', 'DESC']]}if(query.title){condition.where={title:{[Op.like]:`%${query.title}%`}}}const articles = await Article.findAll(condition)res.json({code: 200,message: "查询成功",data: {articles}});} catch (error) {res.status(500).json({code: 500,message: "查询失败",errors: [error.message]})}});

5.根据id查询相关内容

router.get('/:id', async function (req, res, next) {try {const { id } = req.paramsconst article = await Article.findByPk(id)if (article) {res.json({code: 200,message: "查询成功",data: {article}});} else {res.status(404).json({code: 404,message: "未查询到数据"})}} catch (error) {res.status(500).json({code: 500,message: "查询失败",errors: [error.message]})}
})

四.总结

    由于我是刚入门NodeJS,所以还只是对sequelize的简单了解,之后有更深的了解再继续分享

这篇关于Sequelize入门及简单的增删改查的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1087928

相关文章

从入门到精通详解Python虚拟环境完全指南

《从入门到精通详解Python虚拟环境完全指南》Python虚拟环境是一个独立的Python运行环境,它允许你为不同的项目创建隔离的Python环境,下面小编就来和大家详细介绍一下吧... 目录什么是python虚拟环境一、使用venv创建和管理虚拟环境1.1 创建虚拟环境1.2 激活虚拟环境1.3 验证虚

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

Java List 使用举例(从入门到精通)

《JavaList使用举例(从入门到精通)》本文系统讲解JavaList,涵盖基础概念、核心特性、常用实现(如ArrayList、LinkedList)及性能对比,介绍创建、操作、遍历方法,结合实... 目录一、List 基础概念1.1 什么是 List?1.2 List 的核心特性1.3 List 家族成

python连接sqlite3简单用法完整例子

《python连接sqlite3简单用法完整例子》SQLite3是一个内置的Python模块,可以通过Python的标准库轻松地使用,无需进行额外安装和配置,:本文主要介绍python连接sqli... 目录1. 连接到数据库2. 创建游标对象3. 创建表4. 插入数据5. 查询数据6. 更新数据7. 删除

Jenkins的安装与简单配置过程

《Jenkins的安装与简单配置过程》本文简述Jenkins在CentOS7.3上安装流程,包括Java环境配置、RPM包安装、修改JENKINS_HOME路径及权限、启动服务、插件安装与系统管理设置... 目录www.chinasem.cnJenkins安装访问并配置JenkinsJenkins配置邮件通知

c++日志库log4cplus快速入门小结

《c++日志库log4cplus快速入门小结》文章浏览阅读1.1w次,点赞9次,收藏44次。本文介绍Log4cplus,一种适用于C++的线程安全日志记录API,提供灵活的日志管理和配置控制。文章涵盖... 目录简介日志等级配置文件使用关于初始化使用示例总结参考资料简介log4j 用于Java,log4c

史上最全MybatisPlus从入门到精通

《史上最全MybatisPlus从入门到精通》MyBatis-Plus是MyBatis增强工具,简化开发并提升效率,支持自动映射表名/字段与实体类,提供条件构造器、多种查询方式(等值/范围/模糊/分页... 目录1.简介2.基础篇2.1.通用mapper接口操作2.2.通用service接口操作3.进阶篇3

Python自定义异常的全面指南(入门到实践)

《Python自定义异常的全面指南(入门到实践)》想象你正在开发一个银行系统,用户转账时余额不足,如果直接抛出ValueError,调用方很难区分是金额格式错误还是余额不足,这正是Python自定义异... 目录引言:为什么需要自定义异常一、异常基础:先搞懂python的异常体系1.1 异常是什么?1.2

Python实现Word转PDF全攻略(从入门到实战)

《Python实现Word转PDF全攻略(从入门到实战)》在数字化办公场景中,Word文档的跨平台兼容性始终是个难题,而PDF格式凭借所见即所得的特性,已成为文档分发和归档的标准格式,下面小编就来和大... 目录一、为什么需要python处理Word转PDF?二、主流转换方案对比三、五套实战方案详解方案1: