Cette fois, je vais vous donner une explication détaillée des étapes de mise en place de sous-tableaux pour les relations entre les modèles Laravel. Quelles sont les précautions pour la mise en place de sous-tableaux pour les relations entre les modèles Laravel. . Ce qui suit est un cas pratique, jetons un coup d'oeil.
Qu'est-ce qu'Eloquent
Eloquent est un ORM, le nom complet est Object Relational Mapping, traduit par "Object Relational Mapping" (si vous il suffit de s'y référer. Il serait trop sous-estimé de le traiter comme une couche d'abstraction de la bibliothèque de tableaux de couches). Ce qu'on appelle « l'objet » est ce que cet article appelle « Modèle » ; le mappage des relations d'objet est la relation entre les modèles. Document chinois : http://laravel-china.org/docs/eloquent#relationships
Quote est souvent utilisé dans le développement réel. Par exemple, si la table utilisateur est divisée en 100 tables, vous devez configurer des sous-tables pour interroger les données. Par exemple, la classe Model de Laravel fournit la méthode setTable :
Ensuite, ajoutez, supprimez, et modifiez la table de données. Vous devez d'abord créer une nouvelle instance de modèle, puis définir le nom de la table. Par exemple :/** * Set the table associated with the model. * * @param string $table * @return $this */ public function setTable($table) { $this->table = $table; return $this; }
(new Circle())->setTable("t_group_" . hashID($userid, 20)) ->newQuery() ->where('group_id', $request->group_id) ->update($attributes);
Je n'ai pas trouvé de bonne solution après avoir longtemps cherché. En prenant HasOne comme exemple, j'ai regardé la méthode d'implémentation de la fonction HasOne de la classe Model Il n'y a pas de place pour mettre la table. nom, j'ai donc dû copier la méthode HasOne et la modifier. Par exemple, remplacez-le par myHasOne, ajoutez le paramètre $table pour définir le nom de la table et appelez setTable une fois l'objet instancié, et cela fonctionnera comme prévu.
Le code est le suivant :Je me demande si vous avez une manière plus élégante.
public function detail() { return $this->myHasOne(Circle::class, 'group_id', 'group_id', 't_group_' . hashID($this->userid, 20)); } public function myHasOne($related, $foreignKey = null, $localKey = null, $table) { $foreignKey = $foreignKey ?: $this->getForeignKey(); $instance = (new $related)->setTable($table); $localKey = $localKey ?: $this->getKeyName(); return new HasOne($instance->newQuery(), $this, $instance->getTable() . '.' . $foreignKey, $localKey); }
Je pense que vous maîtrisez la méthode après avoir lu le cas dans cet article. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur le site Web chinois de php !
Lecture recommandée :
Explication détaillée des étapes Redis du fonctionnement de PHPExplication détaillée des cas d'utilisation du mode PHP singletonCe 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!