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); 
上一篇:php-在Codeigniter中对表格进行排序


下一篇:php-CodeIgniter-类CI_DB_mysqli_result的对象无法转换为字符串