如何在laravel中将对象数组保存到mysql数据库?

时间:2017-09-16 06:10:29

标签: php laravel vue.js

我正在使用带有laravel的vue。我试图保存对象数组但不能这样做,虽然我能够保存单个对象。这是我的代码 App.vue

// Not working
saveData(){
  this.axios.post('/addperson', **this.rows**).then((response) => {
    console.log("WOW");
  })
}

//working
    saveData(){
      this.axios.post('/addperson', **this.rows[0]**).then((response) => {
        console.log("WOW");
      })
    }

这是控制器代码,当我传递数组时,我收到错误。

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\OrderPerson;

class PersonController extends Controller
{
  public function create(Request $request){

      $person = new Person([
        'name' => $request->get('name'),
        'age' => $request->get('age'),
        'user_id' =>$request->get('user_id')''
      ]);

      $person->save();
    return response()->json('Successfully added');
  }
}

任何人都可以帮我保存阵列吗?

1 个答案:

答案 0 :(得分:1)

首先将所有this.rows分配给数据集,然后将其推送到axios调用,如下所示:

saveData(){
    const postData = {
            data: this.rows
        }
  this.axios.post('/addperson', postData).then((response) => {
    console.log("WOW");
  })
}

现在在laravel控制器中,您可以使用foreach来使用此数据集。

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\OrderPerson;

class PersonController extends Controller
{
  public function create(Request $request){

    foreach($request->data as $data)
    {
        $container = new Person([
            'name' => $data['name'],
            'age' => $data['age'],
            'user_id' => $data['user_id']
          ]);

        $container->save();
    }

    return response()->json('Successfully added');
  }
}

希望这有帮助。