我在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);