mysql - 使用codeigniter的事件记录语法增加mysql数据库的字段

标签 mysql sql codeigniter activerecord

我有以下 php-codeigniter 脚本,它尝试使用事件记录语法来增加记录的字段:

$data = array('votes' => '(votes + 1)');
$this->db->where('id', $post['identifier']);
$this->db->update('users', $data);

这会产生以下 SQL:

"UPDATEusersSETvotes= '(votes + 1)' WHEREid= '44' "

哪个没有运行,但是这个 SQL 确实做了我正在寻找的事情: "UPDATEusersSETvotes= (votes + 1) WHEREid= '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/

相关文章:

php - 相当于 PHP multi_query 的 Codeigniter 是什么

php - Mysql where 子句在 codeigniter 中不起作用

mysql - Laravel Schema onDelete设置默认值

php - 如何使用php将字符串添加到MYSQL数据库,并删除其中的字符串的最后一个字符?

mysql - 如何加速具有多个连接的 Group By 语句?

sql - 行间相减

sql - 在日期不同时加入日期表

php - 在 Codeigniter 中取消设置 session 数组值

php - Paginator Symfony 关于进行查询的建议

sql - Mysql优化