gpt4 book ai didi

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

转载 作者:IT老高 更新时间:2023-10-28 12:54:40 27 4
gpt4 key购买 nike

我有以下 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/

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