Erreur avec Eloquent ORM dans Laravel 4
Question
j'apprends actuellement Laravel et j'essaie de suivre ce tutoriel.Mais j'utilise Laravel 4 et le tutoriel utilise Laravel 3, donc je devrais réparer beaucoup de choses à cause de cela.J'ai cette méthode sur un contrôleur
public function InsertTestData()
{
$logged_in_user = Auth::user();
$photos = array(
array(
'user_id' => $logged_in_user->id,
'location' => 'http://farm6.staticflickr.com/5044/5319042359_68fb1f91b4.jpg',
'description' => 'Dusty Memories, The Girl in the Black Beret (http://www.flickr.com/photos/cloudy-day/)'
),
array(
'user_id' => $logged_in_user->id,
'location' => 'http://farm3.staticflickr.com/2354/2180198946_a7889e3d5c.jpg',
'description' => 'Rascals, Tannenberg (http://www.flickr.com/photos/tannenberg/)'
),
array(
'user_id' => $logged_in_user->id,
'location' => 'http://farm7.staticflickr.com/6139/5922361568_85628771cd.jpg',
'description' => 'Sunset, Funset, Nikko Bautista (http://www.flickr.com/photos/nikkobautista/)'
)
);
$logged_in_user->photos()->save($photos);
}
et c'est le modèle que j'ai utilisé
class User extends Eloquent implements UserInterface, RemindableInterface {
public function photos()
{
return $this->hasMany('Photo');
}
}
ça renvoie une erreur comme celle-ci
Argument 1 passed to Illuminate\Database\Eloquent\Relations\HasOneOrMany::save() must be an instance of Illuminate\Database\Eloquent\Model, array given, called in /Library/WebServer/Documents/webpraktek/app/controllers/DashboardController.php on line 44 and defined
la ligne 44 est cette ligne
$logged_in_user->photos()->save($photos);
c'est un modèle pour la photo de classe
class Photo extends Eloquent
{
public function user()
{
return $this->belongsTo('User');
}
public function photocomments()
{
return $this->hasMany('PhotoComment');
}
}
je ne sais rien pour résoudre ce problème, car j'apprends encore.pourquoi est-ce arrivé ?est-ce que la différence dans la version de Laravel provoque ce genre d'erreur ?merci
MODIFIER:je l'ai réparé avec ça pour l'instant,
foreach($photos as $photo) {
$photos = new Photo();
$photos->user_id = $photo['user_id'];
$photos->location = $photo['location'];
$photos->description = $photo['description'];
$photos->save();
}
La solution
Autant que je puisse dire, votre exemple ne fonctionne pas car vous ne créez pas de nouveau modèle photo.
Essayez de remplacer ceci:
$logged_in_user->photos()->save($photos);
avec:
foreach ($photos as $photoData) {
$photo = new Photo($photoData);
$logged_in_user->photos()->save($photo);
}
Autres conseils
Vous n'avez pas besoin d'utiliser $logged_in_user
à associer car vous avez déjà les identifiants définis dans le tableau, alors utilisez simplement create
plutôt.
Photo::create($photos);