连接以打开 sequelize 连接
Connecting to open sequelize connection
我创建了一个 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);
});
});
});
感谢 终于解决了这个问题
- 我在 bin 中为我的数据库连接创建了一个新文件 (db.js) 并导出 sequelize 做 module.exports = sequelize;
然后我可以在做 var sequelize = require('../../../bin/db');
时要求它
我仍然不确定为什么我之前的方法不起作用 - 当我在我的其他文件中需要它时,从 bin/www 导出的结果返回了一个空对象。我认为这与异步行为有关,因为 bin/www 在我启动 nodemon 时被调用。
如果您有任何想法,请随时发表评论。
我创建了一个 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);
});
});
});
感谢 module.exports = sequelize;
然后我可以在做 var sequelize = require('../../../bin/db');
我仍然不确定为什么我之前的方法不起作用 - 当我在我的其他文件中需要它时,从 bin/www 导出的结果返回了一个空对象。我认为这与异步行为有关,因为 bin/www 在我启动 nodemon 时被调用。
如果您有任何想法,请随时发表评论。