Sequelize 是一个基于 Promise 的 ORM (Object-Relational Mapping)库,它允许我们与多种数据库类型进行交互。它提供了一些数据操作语句来进行数据的创建,读取,更新和删除。在本文中,我们将详细说明这些语句的用法以及它们在实际项目中的实现。
1. 数据库连接
在使用 Sequelize 之前,我们需要将其连接到数据库。连接操作通常需要数据库的连接字符串或者环境变量。下面是一个基本示例:
const { Sequelize } = require('sequelize'); const sequelize = new Sequelize('database', 'username', 'password', { host: 'localhost', dialect: 'mysql' // 'mysql' | 'mariadb' | 'postgres' | 'mssql' });
2. 定义模型
在 Sequelize 中,模型是对数据表的一种抽象。我们需要定义模型来实现对数据的操作。下面是一个示例:
-- -------------------- ---- ------- ----- - --------- - - --------------------- ----- ---- - ------------------------ - -- ----- ---------- --- ------- ---- ---------- - ----- ----------------- ---------- ----- -- --------- - ----- ---------------- -- --------- -------- -- ---- -- ---- - ----- ----------------- -- --------- -------- -- ---- - -- - -- ----- ----- ------- -- ---- ---
其中,我们定义了一个名为 User
的模型,并给它三个属性:firstName
,lastName
,age
。我们可以指定每个属性的类型,还可以设置属性是否允许为空。定义模型后,Sequelize 将会根据模型自动生成对应的数据表。
3. 数据增删改查
3.1 创建数据
在 Sequelize 中,我们可以使用 create
方法来创建一条数据。它接收一个对象参数,对象的键值对对应着数据表的列和值。示例:
User.create({ firstName: 'John', lastName: 'Doe', age: 30 });
3.2 查询数据
Sequelize 提供了丰富的查询语句,可以满足各种查询需求。下面是一些常见的查询语句:
3.2.1 查询所有数据
User.findAll();
3.2.2 根据条件查询数据
User.findOne({ where: { firstName: 'John' } }); User.findAll({ where: { age: { [Op.gt]: 18 } } });
上面的示例分别查询了名字为 John
的数据,以及年龄大于 18
的所有数据。
3.2.3 查询特定的列
User.findAll({ attributes: ['firstName', 'lastName'] });
上面的示例查询了 firstName
和 lastName
两列数据。
3.2.4 分页查询
User.findAll({ limit: 10, offset: 0 });
上面的示例查询了第 1-10
行的数据。
3.3 更新数据
在 Sequelize 中,我们可以使用 update
方法来更新数据。它接收两个参数,要更新的数据和更新条件。示例:
User.update({ age: 25 }, { where: { firstName: 'John' } });
3.4 删除数据
在 Sequelize 中,我们可以使用 destroy
方法来删除数据。它接收一个删除条件对象参数。示例:
User.destroy({ where: { firstName: 'John' } });
4. 总结
Sequelize 是一个强大的 ORM 库,可以让我们更轻松地与多种数据库类型进行交互。我们可以使用 Sequelize 提供的丰富的数据操作语句来实现数据的增删改查。本文详细说明了这些语句的用法和示例,希望对初学者有帮助。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/653dfcfb7d4982a6eb7965de