【问题标题】:sequelize raw query in express app在快速应用程序中对原始查询进行续集
【发布时间】:2018-06-04 11:11:52
【问题描述】:

我正在尝试调用一个简单的 sequelize 原始查询来获取 users 表中的所有用户,但我收到了错误。

无法读取未定义的属性“查询”

我在这里做错了什么?

models/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}/../config/config.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(file =>
    (file.indexOf('.') !== 0) &&
    (file !== basename) &&
    (file.slice(-3) === '.js'))
  .forEach(file => {
    const model = sequelize.import(path.join(__dirname, file));
    db[model.name] = model;
  });

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

db.sequelize = sequelize;

module.exports = db;

控制者/用户

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

module.exports = {

  getAllUsers(req, res){
    db.query('SELECT * FROM "Users" As Users', { type: sequelize.QueryTypes.SELECT})
    .then(result => {
      return res.status(201).send({
        result
      });
    })
  }
};

【问题讨论】:

    标签: sql postgresql express sequelize.js


    【解决方案1】:

    不得不改变

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

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

    并添加const sequelize = require('sequelize');

    【讨论】:

      猜你喜欢
      • 2018-01-08
      • 2017-01-25
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多