【问题标题】:Connecting to open sequelize connection连接以打开 sequelize 连接
【发布时间】:2016-07-12 20:48:42
【问题描述】:

我创建了一个 Ionic 应用程序并让前端正常工作。现在,我专注于使用 Node 和 Sequelize 进行 PostgreSQL 数据库连接的后端。

我在bin/www 中创建了连接,并尝试在我的models/user.js 文件中使用它(以创建用户模型),并在我的一个路由文件(index.js)中尝试创建一个新用户并将其添加到数据库中。

我之前没有使用过 Sequelize,所以我不确定我的组织流程是否正确。我正在尝试使用module.exports 将连接从一个文件传递到另一个文件,但它实际上是在传递undefined

"GET /api/home 500 7.717 ms - 2567 TypeError: Cannot read property 'sync' of undefined
        at /Users/me/app/server/routes/api/index.js:13:12"

有没有更好的方法来做到这一点?

这是bin/www 文件:

var pg = require('pg');
var Sequelize = require("sequelize");

//DB CONNECTION
var sequelize = new Sequelize('dbname', 'postgres', 'password', {
  host: 'localhost',
  port: '5434',
  dialect: 'postgres',
  pool: {
    max: 5,
    min: 0,
    idle: 10000
  },
});

sequelize.authenticate().then(function(err) {
    if (err) console.log('Unable to connect to the PostgreSQL database:', err);
    console.log('Connection has been established successfully.');
});

module.exports.sequelize = sequelize;

这是我的models/user.js

var Sequelize = require("sequelize");
var sequelize = require("../bin/www").sequelize;

module.exports = function(sequelize, DataTypes) {
  var User = sequelize.define('user', {
    fb_access_token: {
      type: Sequelize.STRING
    },
    fb_id: {
      type: Sequelize.STRING
    },
    book_wishlist: {
      type: Sequelize.ARRAY
    }
  }, {
    freezeTableName: true
  });
  return User;
}

这是index.js 路线:

var Sequelize = require("sequelize");
var express = require('express');
var router = express.Router();
var sequelize = require("../../../bin/www").sequelize;
var User = require('../../../models/user');

router.get('/home', function(req, res, next) {
  console.log('in router.get to home');
  console.log('User:',User);

  sequelize.sync({ force: true }).success(function(err) {
    //insert new user
    User.create({
      fb_access_token: "yes",
      fb_id: "no",
      book_wishlist: ["yes", "no"]
    }).success(function(user) {
      //you can now access the newly created user via the variable user
      console.log(user);
      res.send(user);
    });
  });
});

【问题讨论】:

  • 在 index.js 中,可以var sequelize = require("../../../bin/www"); console.log(sequelize) 并粘贴输出
  • 啊是的 - 它返回一个空对象:{}
  • 好的,所以从代码的角度来看,您所做的一切都是正确的,但是您遇到了一个棘手的错误。看起来您正在加载不同的文件。 bin/www 是什么?是目录吗?还是字面意思是www.js
  • 感谢您的帮助! bin 是一个目录,其中包含文件 www(可执行文件)。因为它包含在 express 生成器中,所以我在我的大多数项目中都使用过它——我通常将我的猫鼬连接放在那里并创建我的服务器。在这里,我正在做同样的事情,但有续集
  • 该目录是否有一个名为 'index.js' 的文件?如果有,它的内容是什么?

标签: node.js postgresql sequelize.js


【解决方案1】:

感谢Sean's answer in this Stackoverflow question,终于弄明白了 - 我在 bin 中为我的数据库连接 (db.js) 创建了一个新文件并导出了 sequelize 执行 module.exports = sequelize; 然后我可以要求它执行 var sequelize = require('../../../bin/db');

我仍然不确定为什么我之前的方法不起作用 - 当我在其他文件中需要它时,从 bin/www 导出的返回一个空对象。我认为这与异步行为有关,因为我启动 nodemon 时会调用 bin/www。

如果您有任何想法,请随时发表评论。

【讨论】:

    猜你喜欢
    • 2015-04-18
    • 2020-05-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-07-24
    • 2023-03-27
    • 2020-11-17
    • 1970-01-01
    相关资源
    最近更新 更多