gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 21:06:11 25 4
gpt4 key购买 nike

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

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

这会产生以下 SQL:

"UPDATE用户SET投票= '(votes + 1)' WHERE ID = '44'

它不会运行,但这个 SQL 确实做了我正在寻找的事情: "UPDATE用户SET投票= (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 将是:

更新用户 SET votes= votes + 1 WHERE id= '44'

如果您注意到,反引号会从 '(votes+1)' 中删除,这会产生将 votes 属性增加 1 的预期效果。

关于mysql - 使用codeigniter的事件记录语法增加mysql数据库的字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36809260/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com