• Yii ActiveRecord 的via和viaTable示例


    Yii中,将两个不相关的表利用中间表关联有via和viaTable两种方法,这里通过用户权限查询来进行示例。

        

    关系如上,需要建立三个表 用户表 权限表

    用户表

    数据:

    权限表

    数据:

    关联表

    数据:

    然后创建权力模型

    <?php
    
    namespace appmodels;
    
    use yiidbActiveRecord;
    
    class Power extends ActiveRecord
    {
        public static function tableName()
        {
            return 'power';
        }
    }
    

    用户模型

    <?php
    
    namespace appmodels;
    
    use yiidbActiveRecord;
    use appmodelsPower;
    
    class Users extends ActiveRecord
    {
        public static function tableName()
        {
            return 'users';
        }
    
        public function getPower()
        {
            return $this -> hasMany(Power::class, ['id' => 'power_id']) -> viaTable('users-power', ['user_id' => 'user_id']);
        }
    }
    

    关联模型:

    <?php
    
    namespace appmodels;
    
    use yiidbActiveRecord;
    
    class UserPower extends ActiveRecord
    {
        public static function tableName()
        {
            return 'users-power';
        }
    }

    控制器代码

    <?php
    
    namespace appcontrollers;
    
    use yiiwebController;
    use appmodelsUsers;
    use appmodelsPower;
    
    class UserController extends Controller
    {
        public function actionIndex()
        {
            //查询user_id为6的用户权限  
            $user = Users::findOne(['user_id' => 6]);
            print_r( $user -> getPower() -> asArray() -> all());
        }
    }
    

    运行结果:

     其中用户模型中通过viaTable来通过关联表查询

    $this -> hasMany(Power::class, ['id' => 'power_id']) -> viaTable('users-power', ['user_id' => 'user_id']);
    

    各个数组字段参数含义,hasMany第二个数组中,键名为前面的Power::class对应的模型id字段,值为关联表中前面Power::class的id对应的字段,即power表中的id对应关联表中的power_id, viaTable第二个参数数组,键名为关联表中的字段,值为当前primaryModel对应的字段,即关联表中的user_id对应当前user表中的user_id。

    via方法

    via参数为AR类中定义的关联名,修改用户模型:

    <?php
    
    namespace appmodels;
    
    use yiidbActiveRecord;
    use appmodelsPower;
    use appmodelsUserPower;
    
    class Users extends ActiveRecord
    {
        public static function tableName()
        {
            return 'users';
        }
        //通过getUserPower来进行操作
        public function getUserPower()
        {
            return $this -> hasMany(UserPower::class, ['user_id' => 'user_id']);
        }
    
    
        public function getPower($uid = 6)
        {
            return $this -> hasMany(Power::class, ['id' => 'power_id']) -> via('userPower');
        }
    }
    

    运行:

  • 相关阅读:
    博客系统-验证码相关
    博客系统-登录注册
    Django-wsgi实例
    Django-启动文件的制作
    css实现轮播效果图
    Django-celery分布式任务
    无聊。。。。。
    Nginx简单了解
    IIC知识
    BootLoader的一些知识
  • 原文地址:https://www.cnblogs.com/yangxunwu1992/p/5954615.html
Copyright © 2020-2023  润新知