Yii2 hasOne(), hasMany() ʵÏÖÈý±í¹ØÁªµÄ·½·¨(Á½ÖÖ)

5年以前  |  阅读数:683 次  |  编程语言:PHP 

±³¾°£º

ÏÖÓÐ group £¨×e£(C)ºÍ user (Óû§) Á½ÖÖʵÀý¡£

Ò»¸o group ÖпÉÒÔÓµÓжa¸o user£¬Ò»¸o user Ò²¿ÉÒÔÊoÓÚÓжa¸o group £¨¶a¶Ô¶a¹Øϵ£(C)

GroupUserRelation ±iÓÃÓÚ°o¶¨×eºÏ×eÔ±µÄ¹Øϵ£¨Ê¹ÓÃid°o¶¨£(C)

×Ö¶ÎÓÐ id, group_id, user_id

ÏÖÓÐUser(Óû§)±i£¬ ÐeÒª»ñÈ¡ ÆaËuÊoµÄËuÓÐÓû§×eµÄÐÅÏ¢£¬ÐeҪʹÓÃhasMany()½øÐжa±i¹ØÁª¡£


    User.id => GroupUserRelation.user_id
    GroupUserRelation.group_id => Group.id

½¨1


    public function getGroup()
    {
      return $this->hasMany(Group::className(), ['id' => 'group_id'])
         ->viaTable(GroupUserRelation::tableName(), ['user_id' => 'id']);
    }

½¨2


    public function getGroup()
    {
      return $this->hasMany(Group::className(), ['id' => 'group_id'])
         ->viaTable('groupUserRelation');
    }
    public function getGroupUserRelation()
    {
      return $this->hasMany(GroupUserRelation::tableName(), ['user_id' => 'id']);
    }

ÒÔÉÏËuÊoÊÇС±a¸ø´o¼Ò½eÉܵÄYii2 hasOne(), hasMany() ʵÏÖÈý±i¹ØÁªµÄ½¨(Á½ÖÖ)£¬Ï£Íu¶Ô´o¼ÒÓÐËu°iÖu£¬Èç¹u´o¼ÒÓÐÈκÎÒÉÎÊÇe¸øÎÒÁoÑÔ£¬Ð¡±a»a¼°Ê±»Ø¸´´o¼ÒµÄ¡£ÔÚ´ËÒ²*dz£¸Ðл´o¼Ò¶Ô½Å±¾Ö®¼ÒÍøÕ¾µÄÖ§³Ö£¡

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
将二进制数据转为16进制以便显示
获取IMSI
获取IMEI
Java生成UUID
PHP自定义函数获取搜索引擎来源关键字的方法
让你成为最历害的git提交人
在Zeus Web Server中安装PHP语言支持
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Yii2汉字转拼音类的实例代码
Python 2与Python 3版本和编码的对比
php+ajax+json 详解及实例代码
php封装的page分页类完整实例
PHP设计模式之工厂模式与单例模式
php数组合并array_merge()函数使用注意事项
PHP实现简单爬虫的方法
php实现数组中索引关联数据转换成json对象的方法
wget使用技巧