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

相关推荐
Deutsch.8 分钟前
MySQL——主从同步
mysql·adb
猿小喵26 分钟前
MySQL四种隔离级别
数据库·mysql
祁思妙想1 小时前
【LeetCode】--- MySQL刷题集合
数据库·mysql
m0_748248022 小时前
【MySQL】C# 连接MySQL
数据库·mysql·c#
一纸忘忧2 小时前
Bun 1.2 版本重磅更新,带来全方位升级体验
前端·javascript·node.js
东软吴彦祖3 小时前
包安装利用 LNMP 实现 phpMyAdmin 的负载均衡并利用Redis实现会话保持nginx
linux·redis·mysql·nginx·缓存·负载均衡
慵懒的猫mi4 小时前
deepin分享-Linux & Windows 双系统时间不一致解决方案
linux·运维·windows·mysql·deepin
Amy_cx7 小时前
npm install安装缓慢或卡住不动
前端·npm·node.js
码农丁丁7 小时前
为什么数据库不应该使用外键
数据库·mysql·oracle·数据库设计·外键
随心Coding9 小时前
【MySQL】存储引擎有哪些?区别是什么?
数据库·mysql