npm 包 @johnydays/graphql-sequelize 使用教程

GraphQL 是一种数据查询语言,它可以让前端程序员方便地查询后端服务器上的数据。Sequelize 是一个流行的 Node.js ORM(Object-Relational Mapping)用于将关系型数据库映射为对象,用于实现数据存储的抽象层。@johnydays/graphql-sequelize 包是一个将 Sequelize 模型转换为 GraphQL 类型的工具包,可以帮助开发者快速的将 Sequelize 模型导入到 GraphQL 服务器中,这样就不需要编写冗长的 GraphQL 类型定义。在此篇文章中,我将重点介绍该 npm 包的使用,帮助读者了解如何使用并掌握相关技术。

1. 安装

要使用 @johnydays/graphql-sequelize,必须在项目中安装它。可以使用 npm 进行安装:

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

2. 使用

  1. 首先,需要将 Sequelize 模型导入到 GraphQL 服务器中。可以通过创建 GraphQL 填充函数(resolver)来实现此项操作,如下所示:
------ --------- ---- ------------
------ - -------------------- - ---- ----------------
------ - ------------- ----------------- - ---- ---------------------------
------ - --------------- - ---- -------------------------------

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

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

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

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

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

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

attributeFields 是一个函数,它可以将 Sequelize 模型的字段映射为 GraphQL 类型定义的字符串片段。在这个示例中,我们将 UserModel 的字段映射到了 GraphQL 的 User 类型中。

createLoader 是一个函数,它读取所有的 User,做出进一步处理并将其转换为 GraphQL 能够处理的结果。例如,在此示例中我们将用户 ID 转换为数字,并将创建时间和更新时间转换为 Date 类型的 JavaScript 对象。

  1. 接着,我们需要创建一个 GraphQL 查询来获取 User 对象。这可以通过 QueryResolver 完成,如下所示:
----- -------------- - -
    ----- ----- --- - -- -- -- -----------------------
    ------ ------------------------
--

我们创建了两种查询,分别是获取单个用户(user)和获取所有用户(users)。我们使用了 findByPk 方法来查询指定 ID 的用户。对于获取所有用户的查询,我们使用了 GraphQL-sequelize-loader 的 createLoader 函数。

3. 分页

当应用程序处理大量数据时,我们通常需要使用分页。Fortunately, @johnydays/graphql-sequelize 具有内置的分页机制,可以为我们提供这种支持。要使用这个功能,我们需要做以下更改:

  1. 修改 typeDefs(类型定义),如下所示:
----- -------- - -
    ---- ----- -
        -------- ------ -----
        ----------- --------- --------
        ---------------------- ---- ------ ---------------- ------- ----------------- ---------------
    -

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

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

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

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

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

Query 类型中添加了一个新查询 usersConnection,它是用来获取用户分页数据。我们还创建了 UserCon 类型和 PageInfo 类型,用于封装该数据。UserEdge 类型包含带有与 user 相关的数据的节点,以及唯一的 cursor

  1. 重新定义 createLoader 函数,如下所示:
------ - -------------------- ------------- ------------------- - ---- -------------------------------

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

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

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

我们使用了 createBatchLoader 函数,用于批量加载数据。 applyConnectionArgs 函数包装了我们的查询选项,以便将查询限制为要返回的记录数。 在本例中,由于我们是在 user 模型上执行查询,因此我们从 users 数据源中获取了一个用户的列表。我们还将 cursor 序列化为字符串。

4. 结论

经过上文的介绍,我们了解到了如何使用 npm 包 @johnydays/graphql-sequelize。我们可以将 Sequelize 模型导入到 GraphQL 服务器中,以实现数据存储的抽象层,并创建分页查询以获取数据。希望这篇文章为大家提供了指导帮助,对相关技术有所掌握。

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


猜你喜欢

  • npm 包 @jaredhanson/make-node 使用教程

    简介 @jaredhanson/make-node 是一个用于构建 Node.js Native Addon 的简单、易用、灵活的工具。它提供了一组命令行工具,以及一些简单的配置和规则,可以帮助你快速...

    3 年前
  • npm 包 @jazmon/require-env-vars 使用教程

    什么是 @jazmon/require-env-vars 包? 在开发前端应用程序时,环境变量是非常重要的一个因素。环境变量可以帮助开发人员在不同的环境中配置和管理应用程序的不同方面,例如数据库连接字...

    3 年前
  • npm 包 @jzetlen/bowserify 使用教程

    在前端开发过程中,我们常常需要使用 JavaScript 的模块化打包工具进行开发,其中最常用的是 npm 包管理工具和其插件。本文将介绍一款基于 npm 的 @jzetlen/bowserify,它...

    3 年前
  • npm 包 drag-drop.min.js 使用教程

    什么是 drag-drop.min.js? drag-drop.min.js 是一个基于 JavaScript 的 npm 包,用于处理拖放操作。它提供了一套简易的 API,可以让您轻松地将拖动操作应...

    3 年前
  • npm 包 @jmac18/epoch 使用教程

    什么是 @jmac18/epoch @jmac18/epoch 是一个可视化时间范围选择组件,适用于前端开发项目。它提供了强大的时间选择功能,可以在项目中轻松使用。

    3 年前
  • npm 包 drawing.min.js 使用教程

    在前端开发中,我们经常需要使用绘图工具来展示数据。而 drawing.min.js 是一个轻量级、易于使用的 npm 包,可以帮助我们快速创建各种类型的图形。本教程将向您展示如何使用 drawing....

    3 年前
  • npm 包 @jmfirth/lit-html-redux 使用教程

    在前端开发中,我们常常需要使用状态管理库来管理应用中的数据。Redux 是一个流行的状态管理库,但它通常需要大量的样板代码来完成基本的功能。同时,Lit-html 是一个高效的 DOM 更新库,能够保...

    3 年前
  • npm 包 @jworkshop/loadimage 使用教程

    前言 随着 Web 技术的快速发展,图像的处理和使用越来越频繁和重要。而前端工程师在开发过程中,也需要经常使用到图片的加载和处理。在这个时候,我们就需要使用一些工具来简化这些操作的过程。

    3 年前
  • npm 包 @jp928/react-native-circular-action-menu 使用教程

    前言 @jp928/react-native-circular-action-menu 是一个 React Native 的 npm 包,它通过提供一个圆形动作菜单来帮助您实现界面的美化和交互效果。

    3 年前
  • npm 包 "@joakimbeng/yml-reader" 使用教程

    前言 在 Web 开发中,我们经常需要读取一些 YAML 文件来进行数据渲染或其他操作。但是,JavaScript 并没有原生支持 YAML 文件的解析,因此我们需要借助一些第三方工具来实现这个功能。

    3 年前
  • npm 包 @jnupeter/unirest 使用教程

    前言 在前端开发中,经常需要发起网络请求,以获得后端数据或与后台进行交互。而在 JavaScript 中发起网络请求最常用的方法就是使用 Ajax,而如今我们也可以使用更加简单易用、功能更丰富的 np...

    3 年前
  • Java选择排序

    Java基础实例程序 在这个示例中,我们创建一个java程序,实现使用选择排序对数组元素进行排序。 在选择排序算法中,搜索最低的元素并将其排列到适当的位置。用下一个最小的数字交换当前元素。

    3 年前
  • Java插入排序

    Java基础实例程序 下面我们创建一个java程序,实现使用插入排序对数组元素进行排序。 插入排序对于小元素是有好处的,因为排序大量元素它需要更多的时间。 让我们来看看一个简单的java程...

    3 年前
  • Java气泡排序

    Java基础实例程序 在教程中,将创建一个java程序,使用冒泡排序对数组元素排序。 气泡排序算法也被称为最简单的排序算法。 在冒泡排序算法中,数组从第一个元素遍历到最后一个元素。

    3 年前
  • Java阿姆斯壮数(armstrongnumber) 实例

    Java基础实例程序 Java中的阿姆斯壮数(armstrongnumber) 定义:阿姆斯壮数(armstrongnumber) 是等于其数字的立方数之和的数字,例如:0,1,153,370...

    3 年前
  • Java阶乘实例

    Java基础实例程序 Java中的阶乘程序:n的阶乘是所有正整数的乘积。 n的因子由n!来表示。 例如: -- - ------- - -- -- - --------- - --- ...

    3 年前
  • Java回文实例

    Java基础实例程序 Java中的回文数定义:回文数是反向后与原数字也是相同的数字(即:从左边读和从右边读过来都是同一个数字)。 例如,545,151,3454,343,171,4884都是回...

    3 年前
  • Java素数实例

    Java基础实例程序 质数(prime number)又称素数,有无限个。质数定义是:在大于1的自然数中,除了1和它本身以外不再有其他因数的数称为质数。例如,2,3,5,7,11,13,17 ...

    3 年前
  • Java斐波那契数列实例

    Java基础实例程序 在斐波那契数列中,下一个数字是前两个数字的总和,例如:0,1,1,2,3,5,8,13,21,34,55等。斐波那契数列的前两个数字是0和1,第三个数字是前两个数字的和,...

    3 年前
  • npm 包 @javiercejudo/tap 使用教程

    简介 npm 是一个常用的 JavaScript 包管理器,提供了许多有用的包供前端开发者使用。@javiercejudo/tap 就是其中一个非常实用的包,它提供了一种方便的方式来使用单元测试框架 ...

    3 年前

相关推荐

    暂无文章