深入探索 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 应用开发的绝佳选择。

相关推荐
人工智能训练师5 小时前
Ubuntu22.04如何安装新版本的Node.js和npm
linux·运维·前端·人工智能·ubuntu·npm·node.js
Seveny075 小时前
pnpm相对于npm,yarn的优势
前端·npm·node.js
huangql5209 小时前
npm 发布流程——从创建组件到发布到 npm 仓库
前端·npm·node.js
荣达12 小时前
koa洋葱模型理解
前端·后端·node.js
csdn_aspnet13 小时前
Windows Node.js 安装及环境配置详细教程
windows·node.js
会飞的架狗师14 小时前
【MySQL体系】第1篇:从MySQL架构原理到存储的解析
后端·mysql
BXCQ_xuan14 小时前
软件工程实践四:MyBatis-Plus 教程(连接、分页、查询)
spring boot·mysql·json·mybatis
玉衡子15 小时前
七、InnoDB底层原理与日志机制
java·mysql
cyforkk16 小时前
MySQL 唯一约束:从基础到实战,解决数据重复的核心工具
数据库·mysql
快乐肚皮16 小时前
SQL调优全攻略:从原理到实战
mysql