我有以下 php-codeigniter 脚本,它尝试使用事件记录语法来增加记录的字段:
$data = array('votes' => '(votes + 1)');
$this->db->where('id', $post['identifier']);
$this->db->update('users', $data);
这会产生以下 SQL:
"UPDATE
usersSET
votes= '(votes + 1)' WHERE
id= '44'
"
哪个没有运行,但是这个 SQL 确实做了我正在寻找的事情:
"UPDATE
usersSET
votes= (votes + 1) WHERE
id= '44'
"` <--请注意 (votes + 1) 周围没有引号
有谁知道如何使用 codeigniter 的事件记录语法来实现这种类型的查询?
最佳答案
您可以按照以下方式进行:
$this->db->where('id', $post['identifier']);
$this->db->set('votes', 'votes+1', FALSE);
$this->db->update('users');
之所以可行,是因为第三个(可选)FALSE 参数告诉 CodeIgniter 不要使用反引号 ('
) 保护生成的查询。这意味着生成的 SQL 将是:
UPDATE users SET votes= votes + 1 WHERE id= '44'
如果您注意到,反引号会从 '(votes+1)'
中删除,这会产生将 votes 属性增加 1 的预期效果。
关于mysql - 使用codeigniter的事件记录语法增加mysql数据库的字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6373564/