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

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...