在node.js-mysql中执行UPDATE查询不起作用

Executing UPDATE query in node.js mysql not working

本文关键字:UPDATE 查询 不起作用 执行 node js-mysql      更新时间:2023-09-26

我是node.js(以及与之结合的mysql)的新手,正在尝试根据请求参数和请求主体更新我的数据库。我的文件开头是这样的:

var express = require('express');
var bodyParser = require('body-parser');
var mysql = require('mysql');
var connection = mysql.createConnection({
    host: 'localhost',
    user: 'root',
    password: 'root',
    database: 'm3ttulat0r',
    debug: true
});
var app = express();
app.use(bodyParser.json());

我的请求如下:

http://localhost:8080/mettmeister/1

请求正文如下:

{
  "mettmeister": "Jonas"
}

与数据库的连接成功。然后我有以下代码:

app.post('/mettmeister/:mettwochId', function(req, res) {
    var mettmeister = req.body.mettmeister;
    var mettwochId = req.params.mettwochId;
    var query = 'UPDATE mettwoch SET mettmeister = "'+ mettmeister +'" WHERE mettwoch_id = "'+ mettwochId +'"';
    console.log(mettmeister, mettwochId);
    connection.query(query, function(err, result) {
        if (!err) {
            res.status(201);
        } else {
            res.status(500);
        }
    });
});

CCD_ 1返回CCD_ 2。

问题是它发送了请求,服务器根据日志获得了消息,但什么也没发生。服务器显然在执行查询时"停止"了。

我打开了调试,查询看起来很好。

--> ComQueryPacket
{ command: 3,
  sql: 'UPDATE mettwoch SET mettmeister = "Jonas" WHERE mettwoch_id = "1"' }

如果我在数据库中手动执行查询,它会起作用。。我真的很高兴能得到任何帮助。谢谢!:)

使用类似的更新查询

connection.query('UPDATE mettwoch SET ? WHERE ?', [{ mettmeister: mettmeister }, { mettwoch_id: mettwochId }])

嗯,我很愚蠢。对不起,伙计们:(

我做了以下

res.status(201);

事实上,你必须完成这样的请求:

res.status(201).end();