Maison  >  Article  >  développement back-end  >  Le modèle d'association de ThinkPHP

Le modèle d'association de ThinkPHP

不言
不言original
2018-06-07 17:10:493047parcourir

Exemple d'analyse de fonctionnement du modèle d'association ThinkPHP, les amis qui en ont besoin peuvent s'y référer

Habituellement, les relations d'association dont nous parlons incluent les trois types suivants :
◇ Association individuelle : ONE_TO_ONE, incluant HAS_ONE et BELONGS_TO
◇ Association un-à-plusieurs : ONE_TO_MANY, incluant HAS_MANY et BELONGS_TO
◇ Association plusieurs-à-plusieurs : MANY_TO_MANY
Définition de l'association
Fonctionnement CURD de l'association de table de données, relations d'association actuellement prises en charge Y compris les quatre types suivants : HAS_ONE, BELONGS_TO, HAS_MANY, MANY_TO_MANY
Un modèle peut définir plusieurs associations en même temps en fonction de la complexité du modèle économique sans restrictions. Toutes les définitions d'association sont unifiées. dans la variable membre $_link de la classe modèle et peut prendre en charge la définition dynamique. Pour prendre en charge les opérations d'association, la classe modèle doit hériter de la classe RelationModel. Le format de la définition de l'association est :

protected $_link = array( 
' 关联 1' => array( 
' 关联属性 1' => ' 定义 ', 
' 关联属性 N' => ' 定义 ', 
), 
' 关联 2' => array( 
' 关联属性 1' => ' 定义 ', 
' 关联属性 N' => ' 定义 ', 
), 
... 
);

HAS_ONE La définition de la méthode d'association :

class UserModel extends RelationModel 
{ 
public $_link = array( 
'Profile'=> array( 
'mapping_type' =>HAS_ONE, 
'class_name'=>'Profile', 
// 定义更多的关联属性 
…… 
) , 
); 
}

association mapping_type. tapez, c'est dans l'association HAS_ONE La définition de la constante HAS_ONE doit être utilisée à l'intérieur.
class_name Le nom de la classe modèle à associer
mapping_name Le nom du mappage associé, utilisé pour obtenir des données
foreign_key Le nom de la clé étrangère associée
condition La condition associée
mapping_fields Les champs associés à être interrogé
as_fields mappe directement la valeur du champ associé à un champ dans l'objet de données
BELONGS_TO Définition de la méthode d'association :

'Dept'=> array( 
'mapping_type'=>BELONGS_TO, 
'class_name'=>'Dept', 
'foreign_key'=>'userId', 
'mapping_name'=>'dept', 
// 定义更多的关联属性 
…… 
) ,

class_name Nom de la classe modèle à associer
mapping_name Mappage associé name , utilisé pour obtenir des données à l'aide de
foreign_key nom de clé étrangère associée
mapping_fields champ associé à interroger
condition condition associée
parent_key auto-référence champ associé associé
as_fields associe directement la valeur du champ associé Mapper vers un champ dans l'objet de données
HAS_MANY Définition de la méthode d'association :

'Article'=> array( 
'mapping_type' =>HAS_MANY, 
'class_name'=>'Article', 
'foreign_key'=>'userId', 
'mapping_name'=>'articles', 
'mapping_order'=>'create_time desc', 
// 定义更多的关联属性 
…… 
) ,

class_name Nom de la classe modèle à associer
mapping_name Nom du mappage associé, utilisé pour obtenir des données
foreign_key associée nom de la clé étrangère
auto-référence de la clé_parent champs associés associés
condition conditions associées
mapping_fields champs associés à interroger
mapping_limit association pour renvoyer le nombre d'enregistrements
mapping_order tri des requêtes associées
MANY_TO_MANY Définition de la méthode d'association :

"Group"=>array( 
'mapping_type'=>MANY_TO_MANY, 
'class_name'=>'Group', 
'mapping_name'=>'groups', 
'foreign_key'=>'userId', 
'relation_foreign_key'=>'goupId', 
'relation_table'=>'think_gourpUser' 
)

class_name Le nom de la classe modèle à associer
mapping_name Le nom du mappage associé, utilisé pour obtenir des données
foreign_key Le nom de la clé étrangère associée
relation_foreign_key Le nom de clé étrangère de la table associée
mapping_limit Le nombre d'enregistrements à retourner par l'association
mapping_order Le tri de la requête associée
relation_table Le nom de la table associée intermédiaire plusieurs-à-plusieurs
Requête associée
Utiliser la méthode relation Pour les opérations d'association, la méthode relation peut non seulement activer l'association mais également contrôler les opérations d'association locales, rendant tout sous contrôle pour les opérations d'association.

$User = D( "User" ); 
$user = $User->realtion(true)->find(1);

Le résultat de sortie $user peut être similaire aux données suivantes :

array( 
'id'=>1, 
'account'=>'ThinkPHP', 
'password'=>'123456', 
'Profile'=> array( 
'email'=>'liu21st@gmail.com', 
'nickname'=>'流年', 
) , 
)

Écriture associative

$User = D( "User" ); 
$data = array(); 
$data["account"]="ThinkPHP"; 
$data["password"]="123456"; 
$data["Profile"]=array( 
'email'=>'liu21st@gmail.com', 
'nickname' =>' 流年 ', 
) ; 
$result = $User->relation(true)->add($user);

Cela écrira automatiquement Entrée les données de Profil associées.
Mise à jour de l'association

$User = D( "User" ); 
$data["account"]= "ThinkPHP"; 
$data["password"]= "123456"; 
$data["Profile"]=array( 
'email'=>'liu21st@gmail.com', 
'nickname' =>' 流年 ', 
) ; 
$result =$User-> relation(true)->where(‘id=3')->save($data);

Suppression de l'association

$result =$User->relation(true)->delete( "3" );

Ce qui précède est l'intégralité du contenu de cet article. J'espère qu'il sera utile à l'étude de chacun. Veuillez payer. attention au contenu plus connexe. Site Web chinois PHP !

Recommandations associées :

[ThinkPHP] Problèmes de requêtes associés

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