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

相关推荐
m0_6740314314 小时前
GitHub等平台形成的开源文化正在重塑林语堂
windows·mysql·spring
像风一样!21 小时前
MySQL Galera Cluster部署如何实现负载均衡和高可用
数据库·mysql
周杰伦fans1 天前
Navicat - 连接 mysql 、 sqlserver 数据库 步骤与问题解决
数据库·mysql·sqlserver
csdn_aspnet1 天前
如何在 Ubuntu 24.04/22.04/20.04 上安装 MySQL 8.0
linux·mysql·ubuntu
最好结果1 天前
MyBatis 精确查询逗号分隔字符串
mysql·mybatis·1024程序员节
苹果醋31 天前
学习札记-Java8系列-1-Java8新特性简介&为什么要学习Java8
java·运维·spring boot·mysql·nginx
zz-zjx1 天前
MySQL 索引深度指南:原理 · 实践 · 运维(适配 MySQL 8.4 LTS)
运维·数据库·mysql
布朗克1681 天前
MySQL 运算符详细说明
数据库·mysql·运算符·1024程序员节
码力引擎1 天前
【零基础学MySQL】第一章:MySQL介绍与安装
数据库·mysql·1024程序员节
Sam_Deep_Thinking1 天前
MySQL 8 索引与 B+ 树-初浅理解
mysql