Sequelize 在 Node.js 中的快速入门教程

在 Node.js 中使用 Sequelize 可以方便的操作关系型数据库。Sequelize 是一个基于 Promise 的 ORM 框架,支持多种数据库,如 MySQL、PostgreSQL、SQLite、MSSQL 等。本文将为你介绍 Sequelize 的基本概念及使用方式,以帮助你快速掌握它的使用。

安装 Sequelize

安装 Sequelize

使用以下命令安装 Sequelize:

--- ------- ---------

同时还需要安装相应的数据库驱动。

比如使用 MySQL,就需要安装 mysql2 驱动:

--- ------- ------

连接数据库

在使用 Sequelize 之前,我们需要通过 Sequelize 构建一个模型,模型代表数据库中的表。在模型之前,我们需要先进行数据库连接。

----- --------- - ---------------------

----- --------- - --- --------------------- ----------- ----------- -
  ----- ------------
  -------- --------
---

上面代码中,构造了一个 Sequelize 的实例,第一个参数为数据库名称,第二个参数为用户名,第三个参数为密码。其中,dialect 表示数据库类型,这里使用 MySQL 数据库。当然,我们还需要指定 host 选项,表示数据库服务器的主机名或 IP 地址。

这样,我们就成功的连接了数据库,接下来就可以创建一个模型了。

创建模型

定义模型

创建一个模型需要定义它的结构和属性,以及它与其他模型之间的关系。

在 Sequelize 中,模型通过 sequelize.define 方法来定义。例如,下面的代码定义了一个 User 表:

----- ---- - ------------------------ -
  --- -
    ----- ------------------
    ----------- -----
    -------------- ----
  --
  ----- -
    ----- -----------------
    ---------- -----
  --
  ---- -
    ----- ------------------
    ---------- -----
  -
---

上面代码中,我们定义了 User 表,并指定了它的主键、自增属性以及三个字段,分别是 id、name 和 age。其中 id 类型为 INTEGER,是主键,自增,name 和 age 类型均为 STRING 和 INTEGER。

定义关联

关联是模型之间的联系,往往指定了一个模型的实例与其他模型的实例之间的关系。

在 Sequelize 中,我们可以通过 belongsTohasOnehasManybelongsToMany 等方法来定义不同类型的关联。

belongsTo 方法用于关联两个模型中的一对一关系,如:

----- ------- - --------------------------- -
  ------ ----------------
---

----- ---- - ------------------------ -
  ------ -----------------
  ------------ --------------
---

------------------------

上面代码中,我们定义了 Project 模型和 Task 模型,使用 belongsTo 定义了 Task 模型和 Project 模型之间的关系。

hasOnehasMany 方法用于关联两个模型中的一对多关系。

----- ---- - ------------------------ -
  ------ -----------------
  --------- ----------------
---

----- ---- - ------------------------ -
  ------ -----------------
  ------------ --------------
---

-------------------

上面代码中,我们定义了 User 模型和 Task 模型,使用 hasMany 定义了 User 模型和 Task 模型之间的关系。

belongsToMany 方法用于关联两个具有多对多关系的模型,如下面的例子:

----- ------- - --------------------------- -
  ----- -----------------
---

----- ------ - -------------------------- -
  ----- -----------------
---

----------------------------- - -------- --------------- ---
----------------------------- - -------- --------------- ---

上面代码中,我们定义了 Student 模型和 Course 模型,使用 belongsToMany 定义了 Student 模型和 Course 模型之间的关系。

使用模型

定义模型之后,我们就可以使用模型来操作数据库了。

创建记录

使用模型的 create 方法来创建新记录。

----- ---- - ------------------------ -
  --- -
    ----- ------------------
    ----------- -----
    -------------- ----
  --
  ----- -
    ----- -----------------
    ---------- -----
  --
  ---- -
    ----- ------------------
    ---------- -----
  -
---

------ -- -- -
  ----- ---------------- ------ ---- ---

  ----- ---- - ----- -------------
    ----- ----- -----
    ---- --
  ---

  ---------------------------
-----

上面代码中,我们使用 create 方法创建一个新的用户记录,并将它指定为 name 为 John Doe,age 为 30。在 create 调用完之后,它将返回一个 Promise,它将 resolve 为插入的记录对象。

查询记录

使用模型的 findOnefindAll 方法来查询记录。

----- ---- - ------------------------ -
  --- -
    ----- ------------------
    ----------- -----
    -------------- ----
  --
  ----- -
    ----- -----------------
    ---------- -----
  --
  ---- -
    ----- ------------------
    ---------- -----
  -
---

------ -- -- -
  ----- ---------------- ------ ---- ---

  ----- ---- - ----- -------------
    ----- ----- -----
    ---- --
  ---

  ----- --------- - ----- -------------- ------ - ----- ----- ---- - ---

  --------------------------------
-----

上面代码中,我们使用 findOne 方法查询 name 为 "John Doe" 的用户,并将查询结果打印出来。

更新记录

使用记录对象的 save 方法来更新数据库中的记录。

----- ---- - ------------------------ -
  --- -
    ----- ------------------
    ----------- -----
    -------------- ----
  --
  ----- -
    ----- -----------------
    ---------- -----
  --
  ---- -
    ----- ------------------
    ---------- -----
  -
---

------ -- -- -
  ----- ---------------- ------ ---- ---

  ----- ---- - ----- -------------
    ----- ----- -----
    ---- --
  ---

  --------- - ----- -----
  ----- ------------

  ---------------------------
-----

上面代码中,我们使用记录对象的 save 方法来更新 name 属性,并将它保存到数据库中。

删除记录

使用记录对象的 destroy 方法来删除数据库中的记录。

----- ---- - ------------------------ -
  --- -
    ----- ------------------
    ----------- -----
    -------------- ----
  --
  ----- -
    ----- -----------------
    ---------- -----
  --
  ---- -
    ----- ------------------
    ---------- -----
  -
---

------ -- -- -
  ----- ---------------- ------ ---- ---

  ----- ---- - ----- -------------
    ----- ----- -----
    ---- --
  ---

  ----- ---------------

  ---------------------------
-----

上面代码中,我们使用记录对象的 destroy 方法来删除数据库中的记录。

总结

通过本文的介绍,相信大家对 Sequelize 的使用方法有了一个初步的了解。Sequelize 作为一个强大的 ORM 框架,对于 Node.js 中的数据库操作是一个非常重要的组成部分。下一步,我们可以在实际项目中运用 Sequelize,从而更好的掌握它的使用。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/64a67eaa48841e9894321368


猜你喜欢

  • Node.js 中 TCP 连接的建立过程

    TCP 连接是计算机网络中基于面向连接的传输层协议,它提供了可靠的数据传输服务。在 Node.js 中,我们可以使用 net 模块创建 TCP 服务器和客户端。本文将介绍 Node.js 中 TCP ...

    1 年前
  • 在 Express.js 中使用 PM2 进行进程管理

    在 Node.js 的开发中,使用 Express.js 作为服务器框架可以快速地搭建出一个稳定的后端接口,而使用 PM2 进行进程管理可以帮助我们在生产环境中更好地管理和监控我们的进程,增加系统的可...

    1 年前
  • 如何使用 Babel 转换 JSX 和 TypeScript

    如何使用 Babel 转换 JSX 和 TypeScript 在前端开发中,JSX 和 TypeScript 成为了越来越流行的技术。然而,这两种技术并非所有 browsers 和 environme...

    1 年前
  • TypeScript 中如何使用 “联合类型” 完成方法重载

    在 TypeScript 中,我们经常需要对函数进行重载,以实现方法的多态。而对于有多个参数类型的函数重载,使用联合类型是一种非常合适的方式。 什么是联合类型 联合类型是 TypeScript 中的一...

    1 年前
  • ECMAScript 2019 中的 Rest 和 Spread 运算符

    在 ECMAScript 2019 中,Rest 和 Spread 运算符是两个重要的新功能。它们可以帮助前端开发人员更好地处理参数和数据,提供了更灵活和强大的功能。

    1 年前
  • RxJS 实践:使用 first 操作符获取第一个值

    在前端开发中,我们经常处理异步数据流。而 RxJS 是一个流处理库,它提供了一个丰富的操作符来帮助我们处理数据流。其中,first 操作符是一个十分有用的操作符,它可以让我们快速获取流中的第一个值。

    1 年前
  • Sequelize 实现自定义查询语句的方式总结

    Sequelize 是一款基于 Node.js 的 ORM 框架,提供了多种操作数据库的方式。在日常的前端开发工作中,我们经常需要根据自己的需求,在 Sequelize 中实现自定义的查询语句。

    1 年前
  • PM2 集成 Koa 应用的教程指南

    1. PM2 和 Koa 简介 1.1 PM2 PM2 是一个流行的 Node.js 进程管理器,它可以帮助我们管理 Node.js 应用程序的生命周期,包括应用程序的启动、停止、监控、负载均衡等。

    1 年前
  • 网络请求中使用 ECMAScript 2020 新特性: Promise.allSettled()

    近年来,前端开发人员在工作中越来越需要学习和掌握新的 ECMAScript(也称 JavaScript)标准。ECMAScript 2020(ES2020)是最新的 JavaScript 标准,带来了...

    1 年前
  • Mongoose,一款优雅的 MongoDB 对象模型

    Mongoose,一款优雅的 MongoDB 对象模型 将MongoDB作为数据库来存储数据,可以带来许多方便。但是在前端类开发中,使用MongoDB很容易遇到不同的问题,例如数据的不一致,难以常规查...

    1 年前
  • 在 Promise.all 中如何忽略某些请求的响应结果

    前言 在实际开发中,经常会有需要同时处理多个请求的情况。为了实现更高效的并发处理,可以使用 Promise.all 方法。Promise.all 方法接收一个数组参数,数组中的每个元素都是一个 Pro...

    1 年前
  • Hapi 框架中使用 vision 插件渲染视图:详细教程

    标题:Hapi 框架中使用 vision 插件渲染视图:详细教程 在前端开发中,我们经常需要将后台数据渲染到网页上展示给用户,这时候就需要使用视图引擎来进行页面渲染。

    1 年前
  • Angular Bash 高级用法

    在 Angular 开发中,使用 Bash 脚本可以自动化完成许多任务,如自动测试、构建等。本文将介绍一些 Angular Bash 高级用法,帮助开发者更好地进行自动化开发。

    1 年前
  • Redux 以及中间件的使用

    什么是 Redux Redux 是一种状态管理模式,它可以让前端开发更加可预测、可控。它是 React 生态中最流行的状态管理库之一,但它并不限于 React,可以与 Angular、Vue 等框架集...

    1 年前
  • Headless CMS 如何支持多用户协作和编辑

    随着互联网的快速发展,越来越多的网站和应用需要管理和展示大量的内容,而传统的 CMS 由于其繁琐的后端管理界面,日益被 Headless CMS 所代替。Headless CMS 不仅具有前端友好的管...

    1 年前
  • MongoDB 如何解决并发性能低的问题

    背景 随着互联网的不断发展,数据量越来越大,访问量越来越高,对于数据库的并发性能提出了更高的要求。传统关系型数据库在高并发访问时性能下降明显,而非关系型数据库 MongoDB 却可以轻松应对高并发。

    1 年前
  • GraphQL schema 实现数据库 SQL 注入方案

    前言 GraphQL 作为一种新型的 Web API 技术,本质上是一种查询语言,其语言特性使得 GraphQL API 可以轻松地满足前端应用程序的订阅、查询、过滤、分页和排序需求。

    1 年前
  • Performance Optimization 技术和方法的综述

    在前端开发中,性能优化是一个非常重要的问题。随着前端技术的不断发展,网站的各种功能越来越复杂,需要大量的脚本和样式表来实现。这就导致了页面加载的时间变长,影响了用户的体验。

    1 年前
  • 如何使用 Web Components 实现异步数据加载

    Web Components 是一种用于构建可重用组件的 Web 标准,它提供了一种简单的方法来将复杂的应用程序拆分为更小、可维护的部分。通过使用 Web Components,我们可以轻松地创建自定...

    1 年前
  • 使用 Socket.io 和 React.js 构建实时在线聊天室

    实时在线聊天室已经成为许多应用程序的标准组成部分,例如在线游戏、选举投票、音乐比赛等。即时通讯技术可以用来捕捉一系列事件,从而让用户更快地与其他人沟通。 在本文中,我们将学习如何使用 Socket.i...

    1 年前

相关推荐

    暂无文章