Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Array kann nicht in die Datenbank eingefügt werden

Sie versuchen, ein Array innerhalb von for insertStudentData[key] einzufügen .

Versuchen Sie Folgendes:

 $insertStudentData[$key] = array(
        'parent_id'      => $parent_id,
        'email'          => $studentDatas['email'],
        'password'       => $studentDatas['password'],
        'name'           => $studentDatas['name'],
        'nric'           => $studentDatas['nric'],
        'gender'         => $studentDatas['gender'],
        'photo'          => $studentDatas['photo'],
        'is_active'      => $studentDatas['is_active']['0']['photo'],
    );

$this->db->insert('users_student', $insertStudentData[$key]);

Wenn Sie versuchen, mehrere Zeilen einzufügen, können Sie insert_batch

Ich habe Ihren Code auf meiner Seite ausprobiert und er wird vollkommen korrekt. Es fügte der Tabelle mehrere Zeilen hinzu. Das habe ich getan.

function create($studentData){
$insertStudentData = ''; //Create a Variable
    foreach ($studentData => $studentDatas) {

        $insertStudentData[] = array(
            'parent_id'      => $parent_id,
            'email'          => $studentDatas['email'],
            'password'       => $studentDatas['password'],
            'name'           => $studentDatas['name'],
            'nric'           => $studentDatas['nric'],
            'gender'         => $studentDatas['gender'],
            'photo'          => $studentDatas['photo']['0']['photo'],
            'is_active'      => $studentDatas['is_active']
        );

    }

    $this->db->insert_batch('users_student', $insertStudentData[$key]);

    if($this->db->affected_rows() != 1){
        return false;
    } else {
        return true;
    }
}