一个案例带你区分三者关系
1. 首先我们定义三张表,这里用户只允许有一个分组
user_group 用户分组表:id、title
user 用户表:id、user_group_id、username、password
profile 用户信息表:id、user_id、nickname、sex
user表需要关联user_group表,表示每一个 用户需要知道该用户是哪个用户分组的;
profile表需要关联用户表,表示该用户信息数据是哪个用户的信息;
1.1. User模型中需要写的模型关联为
<?php
namespace app\common\model;
use think\Model;
class User extends Model
{
/*用户属于哪个分组*/
public function user_group()
{
return $this->belongsTo('User_group');
}
/*一个用户都有一个个人资料*/
public function profile()
{
return $this->hasOne('Profile');
}
}
1.2. user_group模型中可定义为
<?php
namespace app\common\model;
use think\Model;
class UserGroup extends Model
{
/*一个分组中存在多个用户*/
public function user()
{
return $this->hasMany('User');
}
}
1.3. profile模型中可定义为
<?php
namespace app\common\model;
use think\Model;
class Profile extends Model
{
public function user()
{
return $this->belongsTo('User');
}
}