在编写 Web 应用程序时,数据是至关重要的一部分。Node.js 提供了一些轻量级的数据库,如 SQLite 和 MySQL,但是处理数据库查询时,我们总是需要写大量的 SQL 代码。Sequelize 是一个为 Node.js 编写的 ORM 库,它允许我们使用 JavaScript 语法进行数据库查询,而不需要编写 SQL 代码。在本指南中,我们将介绍 Sequelize 的一些基本查询操作和高级特性。
准备工作
在开始之前,我们需要安装 Sequelize 和数据库驱动程序。我们将使用 MySQL 作为示例数据库,但是 Sequelize 也支持 PostgreSQL、SQLite 和 Microsoft SQL Server。
运行以下命令在 Node.js 项目中安装 Sequelize 和 mysql2:
npm install sequelize mysql2
基本查询操作
创建模型
在 Sequelize 中,我们使用模型(Model)来与数据库进行交互,一个模型对应一个数据库表。我们可以通过实现 sequelize.define
方法来创建一个模型。以下是一个 User
模型的示例:
-- -------------------- ---- ------- ----- --------- - --------------------- ----- --------- - --- --------------------- ----------- ----------- - ----- ------------ -------- ------- --- ----- ---- - ------------------------ - ---------- - ----- ---------------- -- --------- - ----- ---------------- -- ------ - ----- ---------------- -- ---- - ----- ----------------- - --- -----------------
在上面的示例中,我们定义了一个 User
模型,该模型将映射到一个名为 users
的表。我们可以使用 sequelize.sync()
方法来同步模型与数据库。
插入数据
插入数据是我们最常用的查询之一。我们可以使用 create
方法插入一条新记录。以下是一个插入新用户数据的示例:
User.create({ firstName: 'John', lastName: 'Doe', email: 'johndoe@example.com', age: 30 }).then(user => { console.log(user.toJSON()); });
在上面的示例中,我们创建了一个名为 John Doe
的新用户,并将其插入到 users
表中。
查询数据
查询数据是我们最常用的查询之一。我们可以使用 findAll
方法查询一个表中的所有数据。以下是一个查询所有用户数据的示例:
User.findAll().then(users => { console.log(users.map(user => user.toJSON())); });
在上面的示例中,我们检索了 users
表中的所有用户,并将其打印在控制台上。
条件查询
虽然查询所有数据的查询操作很常见,但通常我们需要根据某些条件查询一些指定的数据。我们可以使用 where
选项来添加一个查询条件:
-- -------------------- ---- ------- -------------- ------ - ---------- ------- ---- - ------------------ -- - - ------------- -- - -------------------------- -- ---------------- ---
在上面的示例中,我们查询了 firstName
为 John
并且 age
大于 25
的所有用户。
子查询
有时候我们需要查询嵌套在其他查询中的数据。Sequelize 支持使用嵌套查询来实现这一点。以下是一个查询最年轻的 5 个用户中的地址的示例:
-- -------------------- ---- ------- ----- ----------- - -------------------------- -------------- ----------- ------ ------------ ------------ ------ -- ------ -------- -------- -------- - - ------ ------------ ----------- ----------- ------- -------- - - ------------- -- - -------------------------- -- ---------------- ---
在上面的示例中,我们首先将 UserAddress
模型导入,然后使用 include
选项来指示 Sequelize 将查询结果与 UserAddress
表中相应的记录进行联接。这个查询可以帮助我们找到最年轻的 5 个用户,同时也检索他们的地址数据。
分页
有时候我们需要分页查询数据,以便将数据分成更小的块。我们可以使用 limit
和 offset
选项来实现分页查询。以下是一个查询前 10 个用户的示例:
User.findAll({ limit: 10 }).then(users => { console.log(users.map(user => user.toJSON())); });
在上面的示例中,我们使用 limit
选项来限制只返回前 10
个用户。我们还可以使用 offset
选项来跳过前 10
个用户,以查询接下来的 10 个用户:
User.findAll({ limit: 10, offset: 10 }).then(users => { console.log(users.map(user => user.toJSON())); });
在上面的示例中,我们将 offset
设置为 10
,以直接跳过前 10
个用户,以获取接下来的 10
个用户数据。
排序
有时候我们需要按照某个字段对数据进行排序。我们可以使用 order
选项来实现排序查询。以下是一个按年龄对所有用户升序排序的示例:
User.findAll({ order: [['age', 'ASC']] }).then(users => { console.log(users.map(user => user.toJSON())); });
在上面的示例中,我们使用 order
选项将结果按年龄升序排列。order
选项接受一个数组,该数组的每个元素都是一个数组,其中第一项表示列名,第二项表示排序方向。
计数
有时候我们需要计算表中有多少行数据。我们可以使用 count
方法来实现这一点。以下是一个检索 users
表中的用户数量的示例:
User.count().then(count => { console.log(`There are ${count} users`); });
在上面的示例中,我们使用 count
方法,以获取 users
表中的行数。
高级查询操作
事务
在 Sequelize 中,我们可以使用事务(Transaction)来管理数据库操作。事务是对数据库进行一系列更改的单个逻辑单元,它要么全部完成,要么全部回滚。以下是一个使用事务执行两个数据库操作的示例:
-- -------------------- ---- ------- --------------------------- ----------- -- - ----- ------------- ---------- ------- --------- ------ ------ ---------------------- ---- -- -- - ----------- --- ----- ------------- ---- -- -- - ------ - ---------- ------ -- ----------- --- ---------- -- - ------------------------ ------------ -------------- -- - -------------------------- --------- ------- ---
在上面的示例中,我们使用 sequelize.transaction
方法来创建一个事务,并将两个数据库操作传递给该事务。如果这两个操作都成功完成,该事务将提交。否则,它将回滚,并在选择的错误处理程序中提供有关事务失败的信息。
原始查询
Sequelize 提供了一些 SQL 构造器来帮助我们构造复杂的查询操作。但是,有时候我们需要编写原始 SQL 查询,以获取想要的数据。我们可以使用 query
方法执行原始查询。以下是一个使用原始查询从 users
表中检索数据的示例:
sequelize.query('SELECT * FROM users').then(result => { console.log(result[0]); });
在上面的示例中,我们使用 sequelize.query
方法直接执行 SQL 查询,并将结果作为一个数组返回。这可能对于处理复杂的联接查询非常有用。
结论
在本指南中,我们介绍了 Sequelize 的一些基本查询和高级特性。我们可以使用 Sequelize 执行简单和复杂的查询操作,包括条件查询、子查询、分页、排序、事务和原始查询。这些查询操作可以大大简化数据库查询的编写过程,从而为开发人员提供更多的时间来构建出色的 Web 应用程序。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/66fbce184471362601639a48