我是否需要为每个 MySQL 语句一个新的查询对象?

发布于 2024-11-28 10:14:13 字数 555 浏览 1 评论 0原文

我正在尝试编译多个 MySQL 语句并在同一请求中执行它们,但我不断收到 MySQL 语法错误:

local.sql = "";
for (local.i in this.hitArray)
{
    local.sql &= "UPDATE posts SET viewCount = posts.viewCount + 1 WHERE posts.id = #local.i.postId#;";
}
local.service.setSQL(local.sql);

Raw SQL dump (local.sql var):

UPDATE posts SET viewCount = posts.viewCount + 1 WHERE posts.id = 95;更新帖子 SET viewCount = posts.viewCount + 1 WHERE posts.id = 95;更新帖子 SET viewCount = posts.viewCount + 1 WHERE posts.id = 95;

看起来查询在第一个语句的末尾就被阻塞了。

I'm trying to compile several MySQL statements and execute them in the same request, but I keep getting a MySQL syntax error:

local.sql = "";
for (local.i in this.hitArray)
{
    local.sql &= "UPDATE posts SET viewCount = posts.viewCount + 1 WHERE posts.id = #local.i.postId#;";
}
local.service.setSQL(local.sql);

Raw SQL dump (local.sql var):

UPDATE posts SET viewCount = posts.viewCount + 1 WHERE posts.id = 95;UPDATE posts SET viewCount = posts.viewCount + 1 WHERE posts.id = 95;UPDATE posts SET viewCount = posts.viewCount + 1 WHERE posts.id = 95;

It appears the query is chocking right at the end of the first statement.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

难以启齿的温柔 2024-12-05 10:14:13

MySQL默认禁用多语句以防止sql注入。您必须添加 allowMultiQueries 标记到您的连接字符串以启用它们。

注意:显然,如果您启用多个语句,那么所有查询都使用 cfqueryparam 或 addParam 非常重要,因为您现在面临 sql 注入的风险。

MySQL disables multiple statements by default to prevent sql injection. You must add the allowMultiQueries flag to your connection string to enable them.

Note: Obviously if you enable multiple statements, it is very important all of your queries use cfqueryparam or addParam because you are now at risk for sql injection.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文