node-mysql multiple statements in one query(node-mysql 一个查询中的多条语句)
问题描述
我使用的是 nodejs 10.26
+ express 3.5
+ node-mysql 2.1.1
+MySQL-Server 版本:5.6.16
.
I'm using nodejs 10.26
+ express 3.5
+ node-mysql 2.1.1
+
MySQL-Server Version: 5.6.16
.
我有 4 个 DELETE 并且只想要 1 个数据库请求,所以我用;"连接了 DELETE 命令...但它总是失败.
I got 4 DELETE's and want only 1 Database Request, so i connected the DELETE commands with a ";"... but it fails always.
它抛出这个错误:
但是如果我将这个 SQL 粘贴到 PhpMyAdmin 中,它总是成功的...
But if i paste this SQL in PhpMyAdmin it is always successful...
如果我把它写在单个查询中,它也会成功.
If i write it in single query's its succeed, too.
感谢您的帮助!
推荐答案
我猜你正在使用 node-mysql.(但也适用于 node-mysql2)
I guess you are using node-mysql. (but should also work for node-mysql2)
文档 说:
出于安全原因禁用了对多个语句的支持(它如果值没有正确转义,则允许 SQL 注入攻击).
Support for multiple statements is disabled for security reasons (it allows for SQL injection attacks if values are not properly escaped).
多语句查询
要使用此功能,您必须为您的连接启用它:
Multiple statement queries
To use this feature you have to enable it for your connection:
启用后,您可以通过用分号 ;
分隔每个语句来执行包含多个语句的查询.结果将是每个语句的数组.
Once enabled, you can execute queries with multiple statements by separating each statement with a semi-colon ;
. Result will be an array for each statement.
因此,如果您启用了 multipleStatements
,您的第一个代码应该可以工作.
So if you have enabled the multipleStatements
, your first code should work.
这篇关于node-mysql 一个查询中的多条语句的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!