MySQL 中 .query() 和 .execute() 的区别

rom*_*low 5 mysql syntax-error node.js express

我很难理解准备好的语句的实现。我已经做了大量的研究,但我发现的大部分信息要么是断章取义,要么包含的例子比我想要完成的要复杂得多。谁能为我澄清为什么下面第二个示例中的 execute 方法会引发语法错误?

注意:我在这里使用 node-mysql2 包。

controller.js(使用查询mysql方法)

  const db = require("../lib/database");


  async addNewThing(req, res, next) {

    let data = req.body

    const queryString = 'INSERT INTO table SET ?'
    try {
      await db.query(queryString, data)
      res.status(201).json({
        message: 'Record inserted',
        data
      })
    } catch (error) {
      next(error)
    }
  }
Run Code Online (Sandbox Code Playgroud)

记录成功插入数据库


controller.js(使用execute mysql方法)

  const db = require("../lib/database");


  async addNewThing(req, res, next) {

    let data = req.body

    const queryString = 'INSERT INTO table SET ?'
    try {
      await db.execute(queryString, [data])
      res.status(201).json({
        message: 'Record inserted',
        data
      })
    } catch (error) {
      next(error)
    }
  }
Run Code Online (Sandbox Code Playgroud)

导致以下错误:

您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,了解在“?”附近使用的正确语法。在第 1 行


数据

{ thing_id: '987654', thing_name: 'thing' }
Run Code Online (Sandbox Code Playgroud)

rom*_*low 20

使用 时.query(),参数替换是在客户端处理的,包括let data = req.body上面示例中的对象。

使用.execute()准备好的语句参数作为序列化字符串从客户端发送并由服务器处理。由于let data = req.body是一个对象,所以这是行不通的。