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