我想将数据插入codigIgnitor中具有相同ID的两个表中

时间:2018-09-07 18:55:48

标签: php codeigniter codeigniter-database

我的CI_Controller

public function insert()
{

   $insert1 = array('reg_name'=>$this->input->POST("name"),
                   'reg_mob'=>$this->input->POST("mobile"),
                   'reg_address'=>$this->input->POST("address"));
   $insert2 = array('uname'=>$this->input->POST("uname"),
                    'upass'=>$this->input->POST("pass"));
   $this->Insert_model->insertData($insert,$insert2);
 }    

CI模型

public function insertData($insert1,$insert2)
{
    $result1 = $this->db->insert("register",$insert1);
    $reg_id=$this->db->insert_id();
    $result2 = $this->db->insert("login",$insert2);
    $id=$this->db->insert_id();
    $data=array( 'reg_id' => $reg_id, 'id' => $id );
    echo $this->db->insert('login', $data);
 } 

我有两个表注册和登录 reg_id在登录表中为fk 我的键“ id”有重复的条目“ 5”

INSERT INTO `login` (`reg_id`, `id`) VALUES (45, 5)    

1 个答案:

答案 0 :(得分:0)

尝试一下;您要插入两次以相同的值登录,从而导致键重复。

public function insertData($insert1,$insert2)
{
    $this->db->insert("register", $insert1);
    $insert2['reg_id'] = $this->db->insert_id();
    $this->db->insert("login", $insert2);
 }

将登录时的数据库列id更改为auto_increment。还将有助于截断db表以重新开始。