SQLSTATE [HY000]: общая ошибка: 1364 Поле 'id' не имеет значения по умолчанию в Laravel 6 - PullRequest
0 голосов
/ 14 апреля 2020

Здесь я пытаюсь вставить данные в базу данных, но по какой-то причине я не могу вставить данные в базу данных. Это ошибка:

SQLSTATE [HY000]: общая ошибка: 1364 Поле 'id' не имеет значения по умолчанию (SQL: вставить в stages (code, name, description, updated_at, created_at) значения (32, dfs, v c, 2020-04-14 06:02:57, 2020-04-14 06:02:57)) "

Мой код здесь:

StageController. php

<?php


namespace App\Sys\Http\Controllers;

use App\Http\Controllers\Controller;

use Illuminate\Http\Request;

use App\Sys\Model\Stage;

class StageController extends Controller
{

    public function index(Request $request)
    {  
        $per_page = $request->per_page ? $request->per_page : 5;
        $sort_by = $request->sort_by;
        $order_by = $request->order_by;
        return response()->json(['stages' => Stage::orderBy($sort_by, $order_by)->paginate($per_page)],200);
    }

    public function store(Request $request)
    {
        $location= Stage::create([
            'code' =>$request->code,
            'name' =>$request->name,
            'description' =>$request->description
        ]);
        return response()->json(['stage'=>$stage],200);
    }


    public function show($id)                                                                                                                                                           
    {
        $stages = Stage::where('code','LIKE', "%$id%")->orWhere('name','LIKE', "%$id%")->orWhere('description', 'LIKE', "%$id%")->paginate();
        return response()->json(['stages' => $stages],200);
    }



    public function update(Request $request, $id)
    {
       $stage = Stage::find($id);
       $stage->code  = $request->code;
       $stage->name  = $request->name;
       $stage->description  = $request->description;
       $stage->save(); 
       return response()->json(['stage'=>$stage], 200);
    }

    public function destroy($id)
    {
        $stage = Stage::where('id', $id)->delete();
        return  response()->json(['stage'=>$stage],200);
    }

    public function deleteAll(Request $request){
        Stage::whereIn('id', $request->stages)->delete();
        return response()->json(['message', 'Records Deleted Successfully'], 200);
    }
}

Stage. php

<?php

namespace App\Sys\Model;

use Illuminate\Database\Eloquent\Model;

class Stage extends Model
{
    protected $guarded = [];
}

Мой файл миграции:

<?php

use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;

class CreateStagesTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('stages', function (Blueprint $table) {
            $table->uuid('id')->primary();
            $table->string('original_id',36)->default('0')->index();
            $table->string('code',10)->index()->nullable();
            $table->string('name',100);
            $table->string('description',200)->nullable();
            $table->char('created_by',36)->index();
            $table->char('edited_by',36)->index()->nullable();
            $table->timestamps();

            $table->foreign('created_by')->references('id')->on('users');
            $table->foreign('edited_by')->references('id')->on('users');
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('stages');
    }
}

1 Ответ

0 голосов
/ 14 апреля 2020

Для laravel 5.6+ вы можете использовать Str::uuid() для генерации строки uuid;

use Illuminate\Support\Str;
...
public function store(Request $request)
    {
        $uuid = Str::uuid()->toString();
        $location= Stage::create([
            'id' => $uuid,
            'code' =>$request->code,
            'name' =>$request->name,
            'description' =>$request->description
        ]);
        return response()->json(['stage'=>$stage],200);
    }

Для ниже laravel 5.6 вы можете использовать Ramsey\Uuid\Uuid;

use Ramsey\Uuid\Uuid;
...
public function store(Request $request)
    {
        $uuid = Uuid::uuid1()->toString();
        ...
        return response()->json(['stage'=>$stage],200);
    }

Или вы можете написать загрузочный метод для генерации uuid для создания, Eloquent автоматически установит id=uuid для каждого метода создания. Если имеется много моделей с первичным ключом uuid, вы можете написать черту и использовать эту черту в каждой модели.

use Illuminate\Support\Str;
...
class Stage extends Model
{

    /**
     * Boot function from laravel.
     */
    protected static function boot()
    {
        parent::boot();

        static::creating(function ($model) {
            $model->{$model->getKeyName()} = Str::uuid()->toString();
        });
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...