深入探索 Sequelize 的模式和模型使用

Sequelize 是一个基于 Promise 的 Node.js ORM,支持 Postgres、MySQL、MariaDB、SQLite 和 Microsoft SQL Server。它提供了一种高效的方式来管理和与数据库交互,抽象复杂的 SQL 查询,提供了用于 CRUD 操作的简单易用方法等等。本文将通过一个实际场景------管理电子邮件数据,深入探讨 Sequelize 中模式和模型的使用。

定义模型

在 Sequelize 中,模型代表数据库中的表。通过指定模型名称和属性来定义模型,每个属性代表表中的一列。考虑以下示例,它展示了模型定义过程:

javascript 复制代码
const Sequelize = require('sequelize');
const sequelize = new Sequelize('database', 'username', 'password', {
  dialect: 'yourDialect',
});

const Mail = sequelize.define('Mail', {
  subjectDailyReport: {
    type: Sequelize.STRING,
    allowNull: false,
  },
  sendTime: {
    type: Sequelize.DATE,
    allowNull: false,
  },
  // 这里可以定义更多属性
});

此代码段概述了创建一个具有两个字段 subjectDailyReportsendTimeMail 模型。define 方法接受三个参数:模型名称、模型属性和可选的模型选项。

CRUD 操作

Sequelize 模型提供了多种方法来执行 CRUD 操作。这些方法在直接 SQL 查询上提供了高层次的抽象,使数据库交互更直观,减少错误发生。

创建

使用 create 方法向数据库添加新记录。此方法将新行插入到相应的表中:

javascript 复制代码
const createpreSutBooking = async (subjectDailyReport, sendTime) => {
  try {
    const mail = await Mail.create({ subjectDailyReport, sendTime });
    return mail;
  } catch (error) {
    throw error;
  }
};
读取

使用 findOne 方法(用于获取单条记录)和 findAll 方法(用于获取多条记录)可以从数据库检索数据。以下示例演示了获取最近创建的 Mail 记录:

javascript 复制代码
const getpreSutBooking = async () => {
  try {
    const mail = await Mail.findOne({ order: [['createdAt', 'ASC']] });
    return mail;
  } catch (error) {
    throw error;
  }
};
更新

使用 update 方法更新现有记录。此方法对匹配提供的条件的记录应用更新:

javascript 复制代码
const savepreSutBooking = async (data) => {
  try {
    const { subjectDailyReport, sendTime } = data;
    const mail = await Mail.findOne({ order: [['createdAt', 'ASC']] });
    if (mail) {
      const updatedRecord = await mail.update({ subjectDailyReport, sendTime });
      return updatedRecord;
    } else {
      return '没有找到匹配的记录'; // 'No matching record found'
    }
  } catch (error) {
    throw error;
  }
};
删除

使用 destroy 方法从数据库中移除记录。它删除符合指定条件的记录:

javascript 复制代码
const deletepreSutBooking = async () => {
  try {
    await Mail.destroy({ where: {} });
  } catch (error) {
    throw error;
  }
};

此外,为了完全清空表,可以在 destroy 方法中使用 truncate 选项来移除所有记录并重置任何自增值。

结论

Sequelize 提供了一整套强大的特性,用于数据库模式和模型管理,大大简化了执行 CRUD 操作的过程。通过抽象直接的 SQL 查询,Sequelize 允许更可维护和可读的代码,使其成为涉及关系数据库的 Web 应用开发的绝佳选择。

相关推荐
tan180°4 小时前
MySQL表的操作(3)
linux·数据库·c++·vscode·后端·mysql
DuelCode5 小时前
Windows VMWare Centos Docker部署Springboot 应用实现文件上传返回文件http链接
java·spring boot·mysql·nginx·docker·centos·mybatis
浪裡遊5 小时前
React Hooks全面解析:从基础到高级的实用指南
开发语言·前端·javascript·react.js·node.js·ecmascript·php
幽络源小助理5 小时前
SpringBoot基于Mysql的商业辅助决策系统设计与实现
java·vue.js·spring boot·后端·mysql·spring
whale fall6 小时前
npm install安装的node_modules是什么
前端·npm·node.js
会飞的鱼先生6 小时前
Node.js-http模块
网络协议·http·node.js
爬山算法7 小时前
MySQL(116)如何监控负载均衡状态?
数据库·mysql·负载均衡
用户3521802454759 小时前
MCP极简入门:node+idea运行简单的MCP服务和MCP客户端
node.js·ai编程
觅_15 小时前
Node.js 的线程模型
node.js
KellenKellenHao16 小时前
MySQL数据库主从复制
数据库·mysql