Преобразование массива в строку во входных данных JSON Laravel - PullRequest
0 голосов
/ 11 октября 2018

Я пытаюсь ввести некоторые данные JSON в таблицу между Laravel, но я получаю массив в строку Conersion.

Это мой JSON:

{
  "data": [
    {
      "client_id": "3",
      "vehicle_id": "3",
      "cart1_id": "3",
      "cart2_id": "3",
      "driver1_id": "3",
      "driver2_id": "3",
      "shipper_id": "3",
      "transportationtype_id": "1",        
      "startdatetime": "2018-10-10 11:00:00",
      "enddatetime": "2018-10-10 18:00:00",
      "consultnumber": "3",
      "consultvalidity": "2018-10-20",
      "escorted": "1",                     
      "escortcompany": "Teste",
      "escortplate": "ABC-1234",
      "escorttrackingtecnology": "1",      
      "escorttrackingserial": "123",
      "contactname": "José",
      "contacttel": "17-997157517",
      "decoy": "0",                       
      "decoytrackingtecnology": "1",      
      "decoyserial": "9999",
      "decoysite": "www",
      "decoylogin": "123",
      "decoypassword": "bacd",
      "charged": "1",                 
      "charge": [
        {
          "description": "Teste Carga 1",
          "nf": "1234",
          "amount": "1000.00"
        },
        {
            "description": "Teste Carga 2",
            "nf": "4321",
            "amount": "2000.00"
        }
      ]
    }
  ]
}

А это мой контроллер:

public function storeapi(Request $request)
{
            $array = $request->all();
            $insertedIds = [];

            foreach ($array['data'] as $row) {

                $validator = Validator::make($array['data'], [
                    $row['vehicle_id'] => 'required',
                    $row['driver1_id'] => 'required',
                ]);

                if($validator->fails()) {
                    return response()->json([
                        'message'   => 'Validation Failed',
                        'errors'    => $validator->errors()->all()
                    ], 422);
                }


                $newSm = Sm::create([
                    'client_id' => $row['client_id'],
                    'veiculo_id' => $row['vehicle_id'],
                    'carreta1_id' => $row['cart1_id'],
                    'carreta2_id' => $row['cart2_id'],
                    'motorista1_id' => $row['driver1_id'],
                    'motorista2_id' => $row['driver2_id'],
                    'embarcador_id' => $row['shipper_id'],
                    'tipotransporte_id' => $row['transportationtype_id'],
                    'inicioprevisao' => $row['startdatetime'],
                    'fimprevisao' => $row['enddatetime'],
                    'nroliberacao' => $row['consultnumber'],
                    'datavigencia' => $row['consultvalidity'],
                    'escolta' => $row['escorted'],
                    'empresa' => $row['escortcompany'],
                    'placaescolta' => $row['escortplate'],
                    'tecnologia_id' => $row['escorttrackingtecnology'],
                    'serial' => $row['escorttrackingserial'],
                    'nomecontato' => $row['contactname'],
                    'telefonecontato' => $row['contacttel'],
                    'isca' => $row['decoy'],
                    'tecnologiaisca_id' => $row['decoytrackingtecnology'],
                    'serialisca' => $row['decoyserial'],
                    'siteisca' => $row['decoysite'],
                    'login' => $row['decoylogin'],
                    'senha' => $row['decoypassword'],
                    'status_id' => "1"
                ]);

                $insertedIds[] = $newSm->id;

                foreach ($row['charge'] as $key => $charge){
                    $carga = new Carga();
                    $carga->descricao = $charge['description'];
                    $carga->nf = $charge['nf'];
                    $carga->valor = $charge['amount'];
                    $carga->sm_id = $insertedIds;
                    $carga->save();
                }
                return response()->json($insertedIds, 201);
         }
}

И это возвращаемая ошибка:

Подсветка \ Database \ QueryException Массив в строку преобразования (SQL: вставить в cargas (descricao, nf, valor, sm_id, updated_at, created_at) значения (Teste Carga 1, 1234, 1000.00, 89, 2018-10-11 16:55:57, 2018-10-11 16:55:57))

Ответы [ 2 ]

0 голосов
/ 11 октября 2018

Используйте это:

$insertedIds[] = $newSm->id;

  foreach ($row['charge'] as $key => $charge){
      $carga = new Carga();
      $carga->descricao = $charge['description'];
      $carga->nf = $charge['nf'];
      $carga->valor = $charge['amount'];
      $carga->sm_id = $newSm->id;
      $carga->save();
  }

, поскольку $newSm->id инициализируется в массиве $insertedIds[] и $carga->sm_id в таблице базы данных. Cargas может иметь тип integer или строку

0 голосов
/ 11 октября 2018

У вас есть $carga->sm_id = $insertedIds;, который записывает массив в базу данных.Ты не сможешь это сделать.Либо сохраните один sm_id, либо сериализуйте массив с помощью serialize($carga->sm_id), либо нормализуйте базу данных, если вам нужно несколько идентификаторов для этой строки, и создайте вторую таблицу и используйте внешний ключ.

РЕДАКТИРОВАТЬ:

Проверяя свой код, вы, вероятно, хотите вместо этого:

$carga->sm_id = $newSm->id;
$carga->save();
...
...