微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php-代码点火器-如果查询结果返回行,如何更新数据库

我在codeigniter中构造查询.如果满足条件,则我想更新数据库中的相应行,如果不满足,则要插入新行.这是我的代码

$query = $this->db->get_where('extra_examples', array('question' => $data['question'],'tag' => $data['tag'] ));
        if ($query->num_rows() > 0){
            $this->db->update('extra_examples', $data);
            return ($this->db->affected_rows() > 0);
        } else {
            $this->db->insert('extra_examples', $data);
            return $this->db->insert_id();
        }

插入工作正常,如果整个数据库中只有一行,则更新工作正常,但是如果存在多行,则更新似乎会更改数据库中的所有行.我希望它仅更改问题= data [‘question’]和tag = data [‘tag]的行.

我究竟做错了什么?

解决方法:

我认为这行有问题:

$this->db->update(‘extra_examples’, $data);

该行仅用值$data更新表.因此,只要条件为true,就会执行该操作并更新所有行.尝试对$data施加一些条件,以便仅选定的行会受到影响.

您可以做的是:

$data = array(
           // put array data
        );

$this->db->where('id', $id); // check where to put 
$this->db->update('mytable', $data); 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐