SequelizeJS 错误:TypeError:User.findAll 不是一个函数

新手上路,请多包涵

我正在将 sequelizejs 与 expressjs 应用程序一起使用。

这是我的用户模型的代码。

用户.js

 module.exports = function(sequelize, DataTypes) {
  var User = sequelize.define('User', {
    first_name: DataTypes.STRING,
    last_name: DataTypes.STRING,
    bio: DataTypes.STRING,
    email: DataTypes.STRING,
    profile_picture: DataTypes.STRING
  }, {
    classMethods: {
      associate: function(models) {
        // associations can be defined here
      }
    }
  }, {
    tableName: 'users'
  });
  return User;
};

这是我的用户控制器

用户组件.js

 const express = require( 'express' )
const router  = express.Router()
const User    = require( '../../models/user' )

router.get( '/user', ( req, res, next ) => {
  User.findAll()
    .then( userResponse => {
      res.status( 200 ).json( userResponse )
    } )
    .catch( error => {
      res.status( 400 ).send( error )
    } )
} )

module.exports = router

但是当我试图获取数据时,它抛出了这个错误:

TypeError: User.findAll 不是 router.get (D:\StateBoard-Project\v2\components\user\userComponent.js:6:8) 在 Layer.handle [as handle_request] (D:\StateBoard-Project \v2\node_modules\express\lib\router\layer.js:95:5) 在下一个 (D:\StateBoard-Project\v2\node_modules\express\lib\router\route.js:137:13) 在 Route。在 Layer.handle [as handle_request] (D:\StateBoard-Project\v2\node_modules\express\lib \router\layer.js:95:5) 在 D:\StateBoard-Project\v2\node_modules\express\lib\router\index.js:281:22 在 Function.process_params (D:\StateBoard-Project\v2\ node_modules\express\lib\router\index.js:335:12) 在下一个 (D:\StateBoard-Project\v2\node_modules\express\lib\router\index.js:275:10) 在 Function.handle (D :\StateBoard-Project\v2\node_modules\express\lib\router\index.js:174:3) 在路由器 (D:\StateBoard-Project\v2\node_modules\express\lib\router\index.js:47: 12)

在此处输入图像描述

这是由 Sequelize 自动生成的 model/index.js 文件。

 const fs        = require( 'fs' )
const path      = require( 'path' )
const Sequelize = require( 'sequelize' )
const basename  = path.basename( module.filename )
const env       = process.env.NODE_ENV || 'development'
const config    = require( __dirname + '/..\database.json' )[env]
const db        = {}

let sequelize
if (config.use_env_variable) {
  sequelize = new Sequelize( process.env[ config.use_env_variable ] )
} else {
  sequelize = new Sequelize( config.database, config.username, config.password, config )
}

fs
  .readdirSync( __dirname )
  .filter( function( file ) {
    return ( file.indexOf( '.' ) !== 0 ) && ( file !== basename ) && ( file.slice( -3 ) === '.js' )
  } )
  .forEach( function( file ) {
    var model = sequelize[ 'import' ]( path.join( __dirname, file ) )
    db[ model.name ] = model
  });

Object.keys( db ).forEach( function( modelName ) {
  if ( db[ modelName ].associate ) {
    db[ modelName ].associate( db )
  }
});

db.sequelize = sequelize
db.Sequelize = Sequelize

module.exports = db

这里缺少什么?

原文由 rakibtg 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 365
2 个回答

你应该在你要使用模型的地方需要 models/index.js,而不是 models/user.js。

 const models = require( '../../models/index');

router.get( '/user', ( req, res, next ) => {
  models.User.findAll()
    .then( userResponse => {
      res.status( 200 ).json( userResponse )
    })
    .catch( error => {
      res.status( 400 ).send( error )
    })
} )

原文由 Yrysbek Tilekbekov 发布,翻译遵循 CC BY-SA 3.0 许可协议

您的 user.js 文件正在导出一个函数,但您从未实例化它。

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

当你需要它时

const User = require('../../models/user')

现在 User 是对该函数的引用。它从哪里得到 sequelizeDataTypes

原文由 borislemke 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题