![](/img/trans.png)
[英]Why does sequelize not recognize the Model? TypeError: Cannot read properties of undefined (reading 'findAll')
[英]TypeError: Cannot read properties of undefined (reading 'findAll')
我收到TypeError: Cannot read properties of undefined (reading 'findAll')
錯誤,我找不到原因。 這是models
文件夾中的index.js
和User.js
文件;
索引.js;
'use strict';
const fs = require('fs');
const path = require('path');
const Sequelize = require('sequelize');
const basename = path.basename(__filename);
const config = require('../../config/database.js');
const db = {};
const sequelize = new Sequelize(config);
fs
.readdirSync(__dirname)
.filter(file => {
return (file.indexOf('.') !== 0) && (file !== basename) && (file.slice(-3) === '.js');
})
.forEach(file => {
const model = sequelize['import'](path.join(__dirname, file));
db[model.hostname] = model;
db[model.username] = model;
db[model.password] = model;
db[model.command] = model;
db[model.status] = model;
db[model.cpu] = model;
db[model.mac] = model;
db[model.info] = model;
});
Object.keys(db).forEach(modelName => {
if (db[modelName].associate) {
db[modelName].associate(db);
}
});
db.sequelize = sequelize;
db.Sequelize = Sequelize;
module.exports = db;
用戶.js;
'use strict';
module.exports = (sequelize, DataTypes) => {
const User = sequelize.define('User', {
/* id : DataTypes.INTEGER, */
hostname: DataTypes.STRING,
username: DataTypes.STRING,
password: DataTypes.STRING,
command: DataTypes.STRING,
status: DataTypes.STRING,
cpu: DataTypes.INTEGER,
mac: DataTypes.STRING,
info: DataTypes.STRING
}, {});
User.associate = function(models) {
// associations can be defined here
};
return User;
};
這是我的控制器UserController.js
文件;
const { User } = require('../models');
module.exports = {
index(req, res) {
User.findAll({})
.then(users => res.json({
error: false,
data: users
}))
.catch(error => res.json({
error:true,
data: [],
error: error
}));
},
create(req, res) {
const { /* id, */hostname,username,password,command,status,cpu,mac,info} = req.body;
User.create({
/* id, */hostname,username,password,command,status,cpu,mac,info
})
.then(user => res.status(201).json({
error: false,
data: user,
message: "new user has been created"
}))
.catch(error => res.json({
error:true,
data: [],
error: error
}));
},
update(req, res) {
const user_id = req.params.id;
const { hostname,username,password,command,status,cpu,mac,info } = req.body;
User.update({
hostname,username,password,command,status,cpu,mac,info
}, {
where: {
id: user_id
}
})
.then(user => res.status(201).json({
error: false,
data: user,
message: 'user has been updated'
}))
.catch(error => res.json({
error: true,
error: error
}));
},
destroy(req, res) {
const user_id = req.params.id;
User.destroy({ where: {
id: user_id
}})
.then(status => res.status(201).json({
error: false,
message: 'user has been deleted'
}))
.catch(error => res.json({
error: true,
error: error
}));
}
}
我不知道是什么導致了這個問題。 如果你能幫忙,我會很高興。這是我的項目目錄;
您將一個空對象傳遞給UserController.js
文件中的User.findAll({})
。
嘗試User.findAll()
,而不是。
昨晚我遇到了同樣的問題,它發生在我身上,因為我在同步 sequelize sequelize.sync()
findAll()
) 。 這就是它返回未定義的原因。 不確定它是否出於同樣的原因發生在您身上,因為您沒有附加 server.js 的代碼。 也可以在findAll({})
中傳遞一個屬性 prop 或去掉花括號。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.