Maison  >  Article  >  développement back-end  >  Comment synchroniser des tableaux et ajouter des champs pivots avec la fonction Laravel sync()

Comment synchroniser des tableaux et ajouter des champs pivots avec la fonction Laravel sync()

Linda Hamilton
Linda Hamiltonoriginal
2024-10-19 17:57:02341parcourir

How to Sync Arrays and Add Pivot Fields with the Laravel sync() Function

Fonction Laravel sync() : synchronisation des tableaux et ajout de champs pivots

La fonction Laravel sync() vous permet de gérer les relations entre les modèles et associez-leur des champs pivots.

Association d'une seule ligne de pivotement

Comme mentionné dans la documentation officielle, vous pouvez spécifier un tableau d'identifiants à synchroniser et associer une seule valeur pivot avec l'un des ID :

<code class="php">$user->roles()->sync(array(1 => array('expires' => true)));</code>

Association de plusieurs lignes pivots

Pour associer plusieurs valeurs pivots à plusieurs ID, créez un tableau d'ID sous forme de clés et de tableaux de valeurs pivot en tant que valeurs :

<code class="php">$syncData = [
    1 => ['expires' => true],
    2 => ['expires' => false],
    ...
];

$user->roles()->sync($syncData);</code>

Dans l'exemple ci-dessus, chaque ID est mappé à un tableau correspondant de valeurs pivot.

Exemple personnalisé

Supposons que vous souhaitiez attribuer plusieurs intervenants à un événement et associer chaque intervenant au champ pivot « is_speaker ». Voici un exemple :

<code class="php">$speakers  = (array) Input::get('speakers'); // related ids

// Create an array of pivot data with 'is_speaker' set to true for all speakers
$pivotData = array_fill(0, count($speakers), ['is_speaker' => true]);

// Combine the speakers array with the pivot data array
$syncData  = array_combine($speakers, $pivotData);

$user->roles()->sync($syncData);</code>

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn