扩展数据类型
你尝试实现的类型很可能已包含在 DataTypes 中. 如果未包含新数据类型,本手册将说明如何自行编写.
Sequelize 不会在数据库中创建新的数据类型. 本教程介绍如何使 Sequelize 识别新的数据类型,并假设已在数据库中创建了这些新的数据类型.
要扩展 Sequelize 数据类型,请在创建任何实例之前执行此操作. 此示例创建一个虚拟的 NEWTYPE
,它复制内置数据类型 Sequelize.INTEGER(11).ZEROFILL.UNSIGNED
.
// myproject/lib/sequelize.js
const Sequelize = require('Sequelize');
const sequelizeConfig = require('../config/sequelize')
const sequelizeAdditions = require('./sequelize-additions')
// 添加新数据类型的函数
sequelizeAdditions(Sequelize)
// 在这个例子中,创建并导出Sequelize实例
const sequelize = new Sequelize(sequelizeConfig)
module.exports = sequelize
// myproject/lib/sequelize-additions.js
module.exports = function sequelizeAdditions(Sequelize) {
DataTypes = Sequelize.DataTypes
/*
* 创建新类型
*/
class NEWTYPE extends DataTypes.ABSTRACT {
// 强制,在数据库中完整定义新类型
toSql() {
return 'INTEGER(11) UNSIGNED ZEROFILL'
}
// 可选,验证器功能
validate(value, options) {
return (typeof value === 'number') && (! Number.isNaN(value))
}
// 可选,sanitizer
_sanitize(value) {
// Force all numbers to be positive
if (value < 0) {
value = 0
}
return Math.round(value)
}
// 可选,发送到数据库之前的值字符串
_stringify(value) {
return value.toString()
}
// 可选,解析从数据库接收的值
static parse(value) {
return Number.parseInt(value)
}
}
DataTypes.NEWTYPE = NEWTYPE;
// 强制,设置 Key
DataTypes.NEWTYPE.prototype.key = DataTypes.NEWTYPE.key = 'NEWTYPE'
// 可选, 在stringifier后禁用转义. 不建议.
// 警告:禁用针对SQL注入的Sequelize保护
// DataTypes.NEWTYPE.escape = false
// 为了简便`classToInvokable` 允许你使用没有 `new` 的数据类型
Sequelize.NEWTYPE = Sequelize.Utils.classToInvokable(DataTypes.NEWTYPE)
}
创建此新数据类型后,你需要在每个数据库方言中映射此数据类型并进行一些调整.