2017-09-06 2 views
0

ich eine Funktion Laden mit einer Beziehung mit einem anderen Tisch machen versucht, aber wenn ich einen neuen Wert in db versuche erstellen habe ich dieses ProblemFehler Laravel SQLSTATE [23000]

SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'album_id' cannot be null (SQL: insert into `photos` (`image`, `album_id`, `updated_at`, `created_at`) values (, , 2017-09-06 17:53:01, 2017-09-06 17:53:01)) 

ich die Nachricht zu verstehen, aber ich verstehe nicht, warum es mich diesen Fehler senden, weil ich diesen Wert am Übergang in der create-Methode sehen diesen Code

public function store(Request $request){ 

    $albumVar = $this->album->create([ 
     'title' => $request->get('title'), 
     'description' => $request->get('description'), 
     'user_id' => $request->get('user_id') 
    ]); 

    $photosEncoded[] = null; 
    $photosCount = 0; 
    foreach ($request->file('photo') as $file){ 
     $names[$photosCount] = $file->getPathName(); 
     $photosEncoded[$photosCount] = (string)Image::make($names[$photosCount])->encode('data-url'); 
     $photosCount++; 
    } 

    for($i = 0; $i<$photosCount; $i++) { 
     $photosVar = $this->album->photo()->create([ 
      'image' => $photosEncoded[$i], 
      'album_id' => $albumVar->id 
     ]); 

     if(!$photosVar) 
      return 'falhou'; 
    } 
    if($albumVar) 
     dd($albumVar); 
    else{ 

     dd($albumVar); 
     return 'falhou 1'; 
    } 
} 

, wenn ich den Wert debuggen $ albumVar-> id, das funktioniert gut ...

mein m odel Foto

class Photo extends Model { 
protected $fillable = ['image','album_id']; 

public function album(){ 
    return $this->belongsTo('App\Album'); 
} 

}

meine Migration

public function up() 
{ 
    Schema::create('photos', function (Blueprint $table) { 
     $table->increments('id'); 
     $table->text('image'); 
     $table->integer('album_id')->unsigned(); 
     $table->foreign('album_id')->references('id')->on('albums')->onDelete('cascade'); 
     $table->timestamps(); 
    }); 
} 

mir jemand bei diesem Problem helfen kann?

+0

Fügen Sie den vollständigen Fehler bitte –

+0

könnten Sie versuchen, Hinzufügen von 'dump ($ albumVar)' unter 'für ($ i = 0; $ i <$ photosCount; $ i ++) {' und zeige die Ausgabe an? – Quezler

+0

hier ist der Dump https://imgur.com/a/6w60I – Lodi

Antwort

0

können Sie wie folgt versuchen,

ersetzen $ this-> Album zu $ albumVar

$photosVar = $albumVar->photo()->create([ 
      'image' => $photosEncoded[$i], 
      'album_id' => $albumVar->id 
     ]); 
+0

Ich löse dies mit $ photo = new Photo; und ändern Sie in der erstellen, aber Ihre Methode ist viel besser, vielen Dank! – Lodi

Verwandte Themen