0

insert_id に問題があります。CodeIgniter を使用しています。いくつかの値を挿入し、その中で返すメソッドがあります

$insert_id=$this->db->insert_id();
return $insert_id;`

この値を同じモデルの別のメソッドで使用したいと考えています。私はそれを試しました:$insert_id=$this->add_teacher_subject();しかし、この方法で最初のメソッドが再び実行され、 last_insert_id を受け取りませんが、この値は +1 です。どうすればこの問題を解決できるか教えてください。

私のモデルは次のとおりです。

 public function add_teacher_subject() {

        $date = new DateTime("now"); 
        $data=array(
            'teacher_id'=>$this->input->post('teacher'),

            'user_id'=>$this->session->userdata['user_id'],

            'created_at'=>$date->format('Y-m-d H:i:s')

        );

        $this->db->insert('student_surveys',$data);
       $insert_id=$this->db->insert_id();
        return $insert_id;

    }
  public function survey_fill() 
    {
          $insert_id=$this->add_teacher_subject();
        if ($this->input->post('answer')) {
            $answers= $this->input->post('answer');           
            if (null !==($this->input->post('submit'))) {
                $date = new DateTime("now"); 
                foreach($answers as $question_id=>$answer)
                {
                    $data = array(
                        'user_id'=>$this->session->userdata['user_id'],
                        'question_id'=>$question_id,
                        'answer'=>$answer,              

                        'student_survey_id' => $insert_id
                    );

                    $this->db->insert('survey_answers', $data);

                }

            }
4

1 に答える 1