sequelize.import is not a function

使用koa2+sequelize+mysql搭建项目过程中,跟着百度的各种文章写(比如这个挺完整的:https://www.cnblogs.com/zjknb/p/12149420.html),然后npm start运行时就报了sequelize.import is not a function这个问题,各种百度,也怀疑过sequelize版本问题,可是就没找着能用的6.3版本的文档,然后重新安装了低版本的npm install sequelize@^5.x.x --save,就没这个问题了。

【2020-12-24更新】
关于v6版本的sequelize.import不能使用问题的解决方案:
参考git上issue:https://github.com/sequelize/sequelize/pull/12175
在这里插入图片描述
这位roychri网友提供方法亲测可行,这里举一个我的例子:
原来的代码:

const { QueryTypes } = require('sequelize');
const db = require('../config/db');//引入mysql的配置文件
const sequelize = db.sequelize;
const daily = sequelize.import('../schema/daily');//引入数据表模型

现改为:

const { QueryTypes, DataTypes } = require('sequelize');
const db = require('../config/db');//引入mysql的配置文件
const sequelize = db.sequelize;
const daily = require('../schema/daily')(sequelize, DataTypes);

本来’…/schema/daily’这个文件里其实也是抛出一个方法,接收了2个参数:

module.exports = function (sequelize, DataTypes){
	//...
}

现在就是改为了用require引入方法,直接传参。

【补充】
config/db.js:

const Sequelize = require('sequelize');
const sequelize = new Sequelize('my-loger', 'root',
    '123456',
    {
        host: 'localhost',
        port: '3306',
        dialect: 'mysql',
        dialectOptions: {
            charset: 'utf8mb4',
            supportBigNumbers: true,
            bigNumberStrings: true
        },
        pool: {
            max: 5,
            min: 0,
            acquire: 30000,
            idle: 10000
        },
        timezone: '+08:00'
    });

module.exports = { sequelize };
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值