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中Request的安装以及简单的使用方法图文教程

《Python中Request的安装以及简单的使用方法图文教程》python里的request库经常被用于进行网络爬虫,想要学习网络爬虫的同学必须得安装request这个第三方库,:本文主要介绍P... 目录1.Requests 安装cmd 窗口安装为pycharm安装在pycharm设置中为项目安装req

SpringBoot简单整合ElasticSearch实践

《SpringBoot简单整合ElasticSearch实践》Elasticsearch支持结构化和非结构化数据检索,通过索引创建和倒排索引文档,提高搜索效率,它基于Lucene封装,分为索引库、类型... 目录一:ElasticSearch支持对结构化和非结构化的数据进行检索二:ES的核心概念Index:

GO语言实现串口简单通讯

《GO语言实现串口简单通讯》本文分享了使用Go语言进行串口通讯的实践过程,详细介绍了串口配置、数据发送与接收的代码实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录背景串口通讯代码代码块分解解析完整代码运行结果背景最近再学习 go 语言,在某宝用5块钱买了个

SpringCloud Stream 快速入门实例教程

《SpringCloudStream快速入门实例教程》本文介绍了SpringCloudStream(SCS)组件在分布式系统中的作用,以及如何集成到SpringBoot项目中,通过SCS,可... 目录1.SCS 组件的出现的背景和作用2.SCS 集成srping Boot项目3.Yml 配置4.Sprin

SpringBoot整合Apache Spark实现一个简单的数据分析功能

《SpringBoot整合ApacheSpark实现一个简单的数据分析功能》ApacheSpark是一个开源的大数据处理框架,它提供了丰富的功能和API,用于分布式数据处理、数据分析和机器学习等任务... 目录第一步、添加android依赖第二步、编写配置类第三步、编写控制类启动项目并测试总结ApacheS

C++简单日志系统实现代码示例

《C++简单日志系统实现代码示例》日志系统是成熟软件中的一个重要组成部分,其记录软件的使用和运行行为,方便事后进行故障分析、数据统计等,:本文主要介绍C++简单日志系统实现的相关资料,文中通过代码... 目录前言Util.hppLevel.hppLogMsg.hppFormat.hppSink.hppBuf

SpringMVC配置、映射与参数处理​入门案例详解

《SpringMVC配置、映射与参数处理​入门案例详解》文章介绍了SpringMVC框架的基本概念和使用方法,包括如何配置和编写Controller、设置请求映射规则、使用RestFul风格、获取请求... 目录1.SpringMVC概述2.入门案例①导入相关依赖②配置web.XML③配置SpringMVC

MySQL索引踩坑合集从入门到精通

《MySQL索引踩坑合集从入门到精通》本文详细介绍了MySQL索引的使用,包括索引的类型、创建、使用、优化技巧及最佳实践,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录mysql索引完整教程:从入门到入土(附实战踩坑指南)一、索引是什么?为什么需要它?1.1 什么

Spring Boot整合Redis注解实现增删改查功能(Redis注解使用)

《SpringBoot整合Redis注解实现增删改查功能(Redis注解使用)》文章介绍了如何使用SpringBoot整合Redis注解实现增删改查功能,包括配置、实体类、Repository、Se... 目录配置Redis连接定义实体类创建Repository接口增删改查操作示例插入数据查询数据删除数据更

Java Lettuce 客户端入门到生产的实现步骤

《JavaLettuce客户端入门到生产的实现步骤》本文主要介绍了JavaLettuce客户端入门到生产的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录1 安装依赖MavenGradle2 最小化连接示例3 核心特性速览4 生产环境配置建议5 常见问题