npm 包 objection 使用教程

简介

Objection 是一个基于 knex.js 的 ORM 框架,提供了各种方便快捷的 SQL 查询方法,支持预加载、关联查询、数据筛选等功能,使用它可以快速地构建出功能强大的 Node.js 应用。

本教程将详细介绍 Objection 的使用方法,包括安装、配置、操作数据库等方面的内容,希望能够帮助大家学习和掌握该框架。

安装

首先需要安装 node.js 和 npm,如果没有的话请先安装。

然后,使用 npm 安装 objection:

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

同时,需要使用一个数据库适配器,例如 MySQL、PostgreSQL、SQLite 等。以 MySQL 为例,安装适配器:

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

配置

  1. 创建数据库

首先需要在 MySQL 中创建一个数据库,例如:

------ -------- ---------------
  1. 创建数据库表

在 objection_demo 数据库中创建表 person:

------ ----- ------ --- --- ------- --- --------------- ---- ------------- --- ---- ----- ------------ --------
  1. 配置 knex.js

在使用 Objection 之前,需要先配置 knex.js。

新建文件 knexfile.js,添加以下内容:

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

其中,client 表示使用的数据库类型,这里使用 MySQL;connection 是连接配置,包括数据库地址(host)、用户名(user)、密码(password)以及要连接的数据库名称(database)。

操作数据库

Model

Model 是 Objection 的核心部分,它用来描述数据表,在应用中通过 Model 的方法来操作数据表。

  1. 创建 Model

新建一个 Person.js 文件,定义 Person Model:

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

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

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

在这里,Person 继承自 Objection 的 Model 类,定义了 tableName 字段,对应到 person 表。

  1. 查询数据

可以通过以下方法查询数据:

  • query():返回一个 knex.js 的查询构造器,可以使用 knex.js 的各种查询方法。
  • findById(id):根据 id 查询数据。
  • query().where(condition):根据条件查询数据,condition 可以是一个普通对象,也可以是一个函数。
  • query().orderBy(column, order):根据指定的列和排序规则进行排序。
  • query().page(pageSize, page):分页查询数据,pageSize 表示每页多少条数据,page 表示当前页数。

示例代码:

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

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

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

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

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

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

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

插入数据

可以通过以下方法插入数据:

  • .$query().insert(data):插入一条数据,data 是一个普通对象。
  • .$query().insertAndFetch(data):插入一条数据,并返回插入后的数据。
  • .$query().insertGraph(data):一次性插入一组数据,数据可以包含关联关系。

示例代码:

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

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

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

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

更新数据

可以通过以下方法更新数据:

  • .$query().patch(data):更新一条数据,data 是一个普通对象。
  • .$query().update(data):更新多条数据,data 是一个普通对象。
  • .$query().upsertGraph(data, options):更新一组数据,包含关联关系。

示例代码:

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

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

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

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

删除数据

可以通过以下方法删除数据:

  • .$query().delete():删除一条数据。
  • .$query().deleteById(id):根据 id 删除数据。

示例代码:

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

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

总结

本教程详细介绍了 Objection 的使用方法,包括安装、配置、操作数据库等方面的内容,并且给出了具体的示例代码。

Objection 是一个功能强大的 ORM 框架,可以在 Node.js 应用中轻松地操作数据库。希望大家能够通过本教程学会 Objection 的使用,并在实际开发中掌握该框架,为日后的工作打下坚实的基础。

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


猜你喜欢

  • npm 包 cryptojs-1sp 使用教程

    在前端开发中,数据的安全性是非常重要的一个问题,特别是在进行数据传输和存储的时候。为此,我们需要使用一些加密算法来保证数据的安全性。 cryptojs-1sp 是一个常用的前端加密算法库,本文将为大家...

    6 年前
  • npm 包 rsp2json 使用教程

    rsp2json 是一个可以将网页请求返回的数据转化为 JSON 格式的 npm 包,可以方便地在前端开发中使用。在本篇文章中,将详细介绍 rsp2json 的使用方法,包括安装、使用、示例代码等内容...

    6 年前
  • npm 包 icsify 使用教程:将日历事件导出为 iCal 格式

    icsify 是一个开源的 npm 包,可以将 JavaScript 对象表示的日历事件转换为 iCal 格式,以方便在各种应用中导入和使用。本教程将详细介绍 icsify 的安装和使用方法,让你能够...

    6 年前
  • npm包 iced-utils 使用教程

    在前端开发中,我们常常需要使用到各种工具来提高开发效率和质量。而这些工具通常是封装在 npm 包中,通过 npm 包管理器来安装和使用。今天,我们要介绍的是一个名为 iced-utils 的 npm ...

    6 年前
  • npm包:iced-test的使用教程

    简介 iced-test是一个用于测试CoffeeScript和JavaScript的库。它是在cucumber.js的基础上开发的,它允许你使用given/when/then风格的测试。

    6 年前
  • npm 包 triplesec 使用教程

    在前端开发中,我们经常需要加密和解密数据,以保护用户的隐私和敏感信息。而 npm 包 triplesec 就是一个可以帮助我们实现加密和解密的工具。本文将对 triplesec 的使用进行详细介绍,包...

    6 年前
  • npm包beautifier使用教程

    在日常的前端工作中,我们经常需要进行代码美化,以便于代码的维护和阅读。如果手动进行代码美化,显然会非常繁琐和耗时,因此我们可以使用一些工具来进行自动化的代码美化。今天我们介绍一款非常流行的npm包--...

    6 年前
  • npm包 ilib-webpack-plugin 使用教程

    在前端开发中,我们经常需要处理国际化问题,而 ilib 是一款非常流行的国际化库。在 webpack 构建时使用 ilib 可以使整个项目的国际化变得更加简单和高效。

    6 年前
  • npm 包 wexp-cli 使用教程

    引言 随着前端技术的不断发展,前端工程化成了一种必须掌握的技能。其中,webpack 是一种非常流行的前端构建工具,而 wexp-cli 是在 webpack 基础上做了二次封装的一个脚手架工具,可以...

    6 年前
  • npm 包 unzip-stream 使用教程

    在前端开发中,经常会遇到需要解压缩文件的情况。而 npm 上的 unzip-stream 包就是一个很好用的解压缩工具。本文将详细介绍该 npm 包的使用方法,帮助读者更好地掌握这一工具,并为解决实际...

    6 年前
  • npm 包 binwrap 使用教程

    简介 在前端开发过程中,我们经常需要使用到一些外部的二进制工具,如编译器、打包工具等。而这些工具的安装和配置往往会比较麻烦,甚至在不同平台上可能还存在兼容性问题。npm 包 binwrap 就是为了解...

    6 年前
  • npm 包 Elm 使用教程

    简介 Elm 是一种用于构建 Web 应用程序的函数式编程语言。它提供了一种优雅、类型安全、高效的方式来处理应用程序状态和 UI 渲染。Elm 还提供了自己的编译器和包管理器,使开发流程更加顺畅和高效...

    6 年前
  • npm包elm-minify使用教程

    在前端开发过程中,压缩JavaScript代码是一个非常重要的步骤。通过压缩JavaScript代码,可以减少文件大小,提高加载速度,以及保护源代码的安全性。本教程主要介绍如何使用npm包elm-mi...

    6 年前
  • npm 包 php-date-formatter 使用教程

    随着互联网技术的不断发展,前端工程师的工作逐渐变得复杂起来。为了提高效率、减少出错,使用一些优秀的 npm 包是刻不容缓的任务。在这里,本文将介绍一款名为 php-date-formatter 的 n...

    6 年前
  • npm 包 concat-cli 使用教程

    简介 在前端开发中,经常会需要将多个文件合并成一个文件,例如将多个 JavaScript 文件合并成一个文件以减少 HTTP 请求次数、将多个 CSS 文件合并成一个文件以加快页面加载速度等等。

    6 年前
  • npm 包 degroote-jquery-datetimepicker 使用教程

    在前端开发中,时间日期选择器是一个常见的元素。而 degroote-jquery-datetimepicker 是一个可以轻松将时间日期选择器集成到你的项目中的 npm 包。本文将介绍如何使用该包。

    6 年前
  • npm 包 doku 使用教程

    介绍 doku 是一个轻量级的文档生成器,能够方便地从 JavaScript 代码中生成漂亮的文档。在前端开发中,良好的文档对团队协作和代码维护都有着很大的帮助。本文将详细介绍如何使用 doku。

    6 年前
  • npm 包 tinytim 使用教程

    如果你需要在前端应用中生成 HTML 格式的文本,那么 npm 包 tinytim 就可以派上用场了。本文将为你提供 tinytim 的详细使用教程,包括安装、使用方法和示例代码。

    6 年前
  • npm包mongoskin使用教程

    概述 mongoskin是一个基于Node.js的MongoDB驱动程序,它提供了简单的接口并支持MongoDB大部分功能。本文将介绍如何使用mongoskin进行MongoDB的开发。

    6 年前
  • npm 包 tracer 使用教程

    前言 在前端开发中,往往需要对代码进行调试,以便更好地发现问题并解决问题。而 npm 包 tracer 则是一款非常方便的调试工具,可以帮助开发者更快速、更准确地进行调试,并且还提供了很多自定义的选项...

    6 年前

相关推荐

    暂无文章