【发布时间】:2019-09-19 00:01:06
【问题描述】:
在我的 Express 应用程序中,我必须向 MySQL 数据库中插入一条新的表记录。我使用 Sequelize 作为 ORM。但是,使用以下设置,我无法做到这一点。当我向 /users/register 方法发送 POST 请求(UserController.signup() 设置为在此路由上执行)时,它会永远等待 POSTman 的响应。我尝试从UserController.signup() 返回一个字符串,然后请求工作正常。
为什么我不能在数据库中插入记录?非常感谢您的每一次帮助。
UserController.js
var User = require('../models/user')
module.exports = {
signUp: (fname,email,password) => {
User.create({ firstName: fname, email: email, password: password }).then(user => {
console.log("New auto-generated ID:", user.id);
});
}
}
models/user.js
'use strict';
module.exports = (sequelize, DataTypes) => {
const User = sequelize.define('User', {
firstName: DataTypes.STRING,
email: DataTypes.STRING,
password: DataTypes.STRING
}, {});
User.associate = function(models) {
// associations can be defined here
};
return User;
};
app.js
var createError = require('http-errors');
var express = require('express');
var db = require('./database')
var cookieParser = require('cookie-parser');
var logger = require('morgan');
var Router = require('./routes/index');
var app = express();
app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(Router);
db.authenticate()
.then(() => {
console.log('Connection has been established successfully.');
})
.catch(err => {
console.error('Unable to connect to the database:', err);
});
app.use(function(req, res, next) {
next(createError(404));
});
app.use(function(err, req, res, next) {
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
res.status(err.status || 500);
});
module.exports = app;
database.js
const Sequelize = require('sequelize');
const sequelize = new Sequelize('test', 'root', '', {
host: 'localhost',
dialect: 'mariadb'
});
module.exports = sequelize
编辑
我把models/user.js改成如下。
'use strict';
var sequelize = require('../database')
var Sequelize = require('sequelize')
const User = sequelize.define('User', {
firstName: Sequelize.STRING,
email: Sequelize.STRING,
password: Sequelize.STRING
}, {});
User.associate = function(models) {
// associations can be defined here
};
module.exports = User;
【问题讨论】:
-
添加
catch看看你遇到了什么错误。 -
我更改了
models/User.js,正如我在编辑下的问题中提到的那样,它工作正常。但是我首先发布的 User 模型是为我定义的一个 sequelize cli。我怎样才能不出错地使用它?
标签: express mariadb sequelize.js