Sequelize 提供了多个 hook,用于在执行数据库操作时执行一些自定义逻辑。以下是一些常用的 Sequelize hook 列表及其作用:
基础版本
beforeValidate
- 作用: 在验证模型实例之前触发。
- 示例:
hooks: { beforeValidate: (instance, options) => { console.log('Before validation:', instance.toJSON()); }, }
afterValidate
- 作用: 在验证模型实例之后触发。
- 示例:
hooks: { afterValidate: (instance, options) => { console.log('After validation:', instance.toJSON()); }, }
beforeCreate
- 作用: 在创建模型实例之前触发。
- 示例:
hooks: { beforeCreate: (instance, options) => { console.log('Before create:', instance.toJSON()); }, }
afterCreate
- 作用: 在创建模型实例之后触发。
- 示例:
hooks: { afterCreate: (instance, options) => { console.log('After create:', instance.toJSON()); }, }
beforeUpdate
- 作用: 在更新模型实例之前触发。
- 示例:
hooks: { beforeUpdate: (instance, options) => { console.log('Before update:', instance.toJSON()); }, }
afterUpdate
- 作用: 在更新模型实例之后触发。
- 示例:
hooks: { afterUpdate: (instance, options) => { console.log('After update:', instance.toJSON()); }, }
beforeDestroy
- 作用: 在销毁模型实例之前触发。
- 示例:
hooks: { beforeDestroy: (instance, options) => { console.log('Before destroy:', instance.toJSON()); }, }
afterDestroy
- 作用: 在销毁模型实例之后触发。
- 示例:
hooks: { afterDestroy: (instance, options) => { console.log('After destroy:', instance.toJSON()); }, }
高级版本
beforeBulkCreate
- 作用: 在批量创建模型实例之前触发。可用于在批量创建前执行一些操作。
hooks: {
beforeBulkCreate: (instances, options) => {
console.log('Before Bulk Create Hook');
}
}
afterBulkCreate
- 作用: 在批量创建模型实例之后触发。可用于在批量创建后执行其他操作。
hooks: {
afterBulkCreate: (instances, options) => {
console.log('After Bulk Create Hook');
}
}
beforeBulkDestroy
- 作用: 在批量销毁模型实例之前触发。可用于在批量销毁前执行一些操作。
hooks: {
beforeBulkDestroy: (options) => {
console.log('Before Bulk Destroy Hook');
}
}
afterBulkDestroy
- 作用: 在批量销毁模型实例之后触发。可用于在批量销毁后执行其他操作。
hooks: {
afterBulkDestroy: (options) => {
console.log('After Bulk Destroy Hook');
}
}
beforeBulkUpdate
- 作用: 在批量更新模型实例之前触发。可用于在批量更新前执行一些操作。
hooks: {
beforeBulkUpdate: (options) => {
console.log('Before Bulk Update Hook');
}
}
afterBulkUpdate
- 作用: 在批量更新模型实例之后触发。可用于在批量更新后执行其他操作。
hooks: {
afterBulkUpdate: (options) => {
console.log('After Bulk Update Hook');
}
}
beforeFind
- 作用: 在执行查找操作之前触发。可用于在查询前执行一些操作。
hooks: {
beforeFind: (options) => {
console.log('Before Find Hook');
}
}
afterFind
- 作用: 在执行查找操作之后触发。可用于在查询后执行其他操作。
hooks: {
afterFind: (result, options) => {
console.log('After Find Hook');
}
}
beforeCount
- 作用: 在执行计数操作之前触发。可用于在计数前执行一些操作。
hooks: {
beforeCount: (options) => {
console.log('Before Count Hook');
}
}
afterCount
- 作用: 在执行计数操作之后触发。可用于在计数后执行其他操作。
hooks: {
afterCount: (result, options) => {
console.log('After Count Hook');
}
}
这些 hooks 允许开发者在执行数据库操作的不同阶段插入自定义逻辑,可以根据需要选择使用它们,以执行与模型实例相关的操作。