Импорт в таблицу 'users', а также импорт в сводные таблицы - PullRequest
0 голосов
/ 04 сентября 2018

Я могу импортировать для таблицы «пользователи», но мне также нужно импортировать в сводные таблицы. Вот мой код из моего UsersController для импорта в таблицу 'users', но возможно ли предоставить данные для сводных таблиц, таких как "user_company", "user_department", путем импорта? Можете ли вы показать мне пример импорта в сводные таблицы? В любом случае это мой код при импорте.

  if( Input::file('file_import') ) {
        $path = Input::file('file_import')->getRealPath();
        $inserts = [];
        Excel::load($path,function($reader) use (&$inserts)
        {
            foreach ($reader->toArray() as $row){
                $inserts[] = ['email' => $row['email'], 'username' => $row
                ['username'], 'password' => $row['password'], 'first_name' => $row['first_name'],'middle_name' => $row['middle_name'], 'last_name' => $row['last_name'], 'gender' => $row['gender'],
                'civil_status' => $row['civil_status'], 'spouse' => $row['spouse'], 'religion' => $row['religion'],'emergency_no' => $row['emergency_no'],'previous_work' => $row['previous_work'],
                'remarks' => $row['remarks'],'course' => $row['course'],'biometrics' => $row['biometrics'],'immediate_head' => $row['immediate_head'],'designation' => $row['designation'],'level' => $row['level'],
                'emp_status' => $row['emp_status'],'dependents' => $row['dependents'],'date_hired' => $row['date_hired'],'regularization_date' => $row['regularization_date'],'remmitance_date' => $row['remmitance_date'],
                'tin' => $row['tin'],'philhealth' => $row['philhealth'],'pagibig' => $row['pagibig'],'sss' => $row['sss'],'umid' => $row['umid'],'phone' => $row['phone'],'avatar' => $row['avatar'],
                'address' => $row['address'],'country_id' => $row['country_id'],'role_id' => $row['role_id'],'birthday' => $row['birthday'],'status' => $row['status']];
            }
        });
    }
  }

    if (!empty($inserts)) {
        DB::table('users')->insert($inserts);
        return back()->with('success','Inserted Record successfully');                  
    }

1 Ответ

0 голосов
/ 04 сентября 2018

Для этого случая есть лучший способ, используя Laravel Eloquent Relationships , но при использовании Laravel Database Query Builder вы должны получить последний вставленный идентификатор и использовать его при следующей вставке в "user_company", " user_department».

$userinsert = DB::table('users')->insert($inserts);

$insertedId = $userinsert->id;

$insertsusercompany = [
'user_id' => $insertedId,
'value1' => 'somedata1',
'value2' => 'somedata2'
]

$usercompany = DB::table('user_company')->insert($insertsusercompany);

... и то же самое для других таблиц, но вы должны использовать Eloquent Relationships, потому что это намного проще.

...