我在db中的给定字段上尝试增加1时出现问题。我尝试了有无活动记录。
我的功能看起来像这样(在我的模型中)
function _set_reads($id){
$this->db->set('reads', 'reads+1', FALSE)
$this->db->where('id', $id);
$this->db->update('article');
}
和
function _set_reads($id){
$sql = 'update article set reads=reads+1 where id=?';
$this->db->query($sql, array($id));
}
我在两种情况下都得到相同的错误,并且出现以下错误消息:
Error Number: 1064
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'reads+1 WHERE `id` = '15'' at line 1
UPDATE `article` SET `reads` = reads+1 WHERE `id` = '15'
我使用的是最新版本的MAMP
答案 0 :(得分:11)
- 需要小修正
$this->db->where('id', $id);
$this->db->set('set_row', '`set_row`+ 1', FALSE);
谢谢
答案 1 :(得分:7)
解决了它: 我不得不改变
$this->db->set('reads', 'reads+1', FALSE)
到
$this->db->set('reads', '`reads+1`', FALSE)
对不起该帖子......
答案 2 :(得分:3)
set() 还会接受可选的第三个参数($escape)
,如果设置为FALSE
,则会阻止数据进行转义。