首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从article_id =?极限?

从article_id =?极限?
EN

Stack Overflow用户
提问于 2014-06-11 22:30:17
回答 2查看 340关注 0票数 1

Doctrine2与Symfony:

代码语言:javascript
复制
$this->get('database_connection')->executeUpdate("DELETE FROM articles 
        WHERE article_id = :article_id 
        LIMIT :quantity", 
    array(
       'article_id' => 1,
       'quantity'   => 2
));

我知道错误:

执行‘从article_id =?限制的文章中删除’时发生异常。使用params 1,2: SQLSTATE42000: 语法错误或访问冲突: 1064您的SQL语法出现了错误;请检查与您的MySQL服务器版本对应的手册,以便在第3行使用接近“2”的正确语法。

如何将参数传递给限制子句?

我不喜欢使用bindValue函数,而是使用executeUpdate函数。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-06-16 03:10:38

问题是,executeUpdatesetParameter 不同,不会自动推断您要设置为值的类型,并将所有参数作为字符串进行威胁。因此,您应该显式地将params设置为整数。

代码语言:javascript
复制
$this->get('database_connection')->executeUpdate("DELETE FROM articles 
        WHERE article_id = :article_id 
        LIMIT :quantity", 
    array(
       'article_id' => 1,
       'quantity'   => 2)
    array(
        \PDO::PARAM_INT,
        \PDO::PARAM_INT
    )
);  
票数 2
EN

Stack Overflow用户

发布于 2014-06-11 22:45:51

您仍然可以使用以下语法执行update,这将在文章中插入第一个值,然后将第二个值插入限制。没有测试,但应该有效

代码语言:javascript
复制
$this->get('database_connection')->executeUpdate("DELETE FROM articles 
        WHERE article_id = ?
        LIMIT ?, 
    array(1,2)
);
票数 -2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24173688

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档