`
hudeyong926
  • 浏览: 2035766 次
  • 来自: 武汉
社区版块
存档分类
最新评论

Yii 多表关联relations

 
阅读更多

1首先多表关联是在models/Self.php的relations里配置的。而且是互配,但有区别。
格式:'VarName'=>array('RelationType', 'ClassName', 'ForeignKey', ...additional options)

需要弄清楚的几点:
1,VarName指什么?  详见下面例2。
2,RelationType。一共有4种分别为self::HAS_MANY, self::BELONGS_TO, self::MANY_MANY, self::HAS_ONE。
3,ClassName。即关联的另一个/model/类名.php。
4,ForeignKey。写了ForeignKey是用主键(ClassName.PK)关联Self.ForeignKey,为空两个表不是用主键关联需要on
5,附加条件

两个表不是用主键关联

'user' => array(self::BELONGS_TO, 'OaskUser', '' ,'on'=>'name=userName and user.type=1' , 'select'=>'TrueName', 'order'=>'sort asc'),

BELONGS_TO(属于): 如果表 A 和 B 之间的关系是一对多,则 表 B 属于 表 A ;
HAS_MANY(有多个): 如果表 A 和 B 之间的关系是一对多,则 A 有多个 B ;
HAS_ONE(有一个): 这是 HAS_MANY 的一个特例,A 最多有一个 B ;
MANY_MANY: 这个对应于数据库中的多对多关系。 由于多数 DBMS 不直接支持 多对多 关系,因此需要有一个关联表将多对多关系分割为一对多关系。在 AR术语中,我们可以解释 MANY_MANY 为 BELONGS_TO 和 HAS_MANY 的组合。

STAT :除了上述的关系类型,一个特殊的关系,称为STAT也支持 可用于进行统计查询(或聚合查询) 。 检索聚合对相关对象的信息,如数量。如 一篇日志共有多少个评论

'detailCounts' => array(self::STAT, 'PurchaseDetail', 'purchase_hid'),

例1,一对多关系 (post和user之间的关系)
(1)models/Post.php

class Post extends CActiveRecord
{
    ......
    public function relations()
    {
        return array(
            'author'=>array(self::BELONGS_TO, 'User', 'author_id'),
            'categories'=>array(self::MANY_MANY, 'Category',
                'tbl_post_category(post_id, category_id)'),
        );
    }
}

其中Post与User的关系是BELONGS_TO(多对一)关系,并通过Post的author_id与User关联。Post中author_id是外键,关联到User中。注:此处的VarName是author,一个对象

(2)models/User.php

class User extends CActiveRecord
{
    ......
    public function relations()
    {
        return array(
            'posts'=>array(self::HAS_MANY, 'Post', 'author_id'),
        );
    }
}

对于User,与Post的关系是属于HAS_MANY(一对多)关系。并通过Post的author_id与Post关联。 由于两者是一对多关系,所以要用posts

 

 

例2,多对多关系。中间表名( 本表外键, many表外键 )

在FailParts.php中

'Users' => array(self::MANY_MANY, 'User', 'fail_parts_user(fail_parts_id, user_id)'),

 在User.php中

'FailParts' => array(self::MANY_MANY, 'FailParts', 'fail_parts_user(user_id, fail_parts_id)'),

由于两者是多对多关系,所以要用Users ,而不是User;要用FailParts,而不是FailPart。此处的Users和FailParts,即为前面的VarName。

 

例3,一对一关系。比较简单,暂略。
2,关于VarName。
对于类A.php,'VarName'=>array('RelationType', 'B', 'ForeignKey', ...additional options)
其中VarName与B基本相同。但未必完全一样。此时就可以在A的views/A/xx.php中通过VarName来访问B及其属性值了。
如果是一对一/一对多:A->VarName->name
如果是多对多:

$users = As->VarName
foreach($users as $u){
   $_tmp_users[] = $u -> getName;
}
userStr = implode(', ', $_tmp_users); 

渴求式加载(eager loading)方式。$posts=Post::model()->with('author','categories')->findAll();

AR scopes

//SchoolDepartment::model()->allDepartmentAndClass($id)->findAll();
public function relations() {
    return array(
        'class' => array(self::HAS_MANY, 'SchoolClass', 'school_department_id'),
    );
}

public function scopes() {
    return array(
        'allDepartmentAndClass',
    );
}

public function allDepartmentAndClass($id) {
    $this->getDbCriteria()->mergeWith(array(
        'with' => "class",
        'condition' => "t.tbl_school_id=$id",
    ));
    return $this;
}

强制查询使用join连接查询

 $criteria->together = true;

 

 
 
 
 
分享到:
评论
3 楼 aig1999 2014-09-03  
引用
BELONGS_TO(属于): 如果表 A 和 B 之间的关系是一对多,则 表 B 属于 表 A ;
 
这里是一对一吧?
2 楼 hao.ke 2014-07-12  
好问题,求解,或者说直接禁用relation这个高级功能???是吗
1 楼 abos 2014-02-11  
  Hi,请问一下, 我在用多了yii 的relation之后,感觉它很方便,但也因此产生了两个问题:
1.会在视图上留下model方面太多的代码,不说数据庫结构改变,单是relation的命名不好修改时,都会留下很多遗留问题;
2.耦合,在各种地方使用了relation,使得模型的代码到处都是,也使得对relation的修改变成了很头疼的一件事情

所以要怎么样才能够正确地使用relation呢?或者不是正确地使用,而是更规范地使用~?

相关推荐

    Yii多表联合查询操作详解

    总之,Yii框架的多表联合查询功能通过CActiveRecord的模型关联机制提供了一种非常便捷的数据库操作方式,让开发者可以更高效地处理复杂的数据关系。开发者需要根据实际项目的具体需求以及对性能和可维护性的要求来...

    Yii中的relations数据关联查询及统计功能用法详解

    Yii 框架中的数据关联查询和统计功能是其Active Record模式的重要组成部分,极大地提高了开发者在处理复杂数据库交互时的效率。在Yii中,数据关联查询允许开发者方便地获取关联模型的数据,而统计功能则可以获取关联...

    Yii2 ActiveRecord多表关联及多表关联搜索的实现

    在实际的开发过程中,我们经常需要处理多个表之间的关联以及根据关联表的字段进行搜索查询, Yii2通过ActiveRecord组件提供了强大的多表关联及搜索功能。 ### 多表关联 在Yii2中,多表关联可以通过定义模型之间的...

    Yii2.0表关联查询实例分析

    在 Web 应用开发中,处理表关联查询是数据库操作的一个重要方面,而Yii2.0 提供了Active Record 模式,使得开发者能够方便地进行表关联查询和数据操作。 首先,Yii2.0 的ActiveRecord 模式允许通过模型层来进行数据...

    详解YII关联查询

    本文将详细介绍Yii框架中如何进行关联查询,包括配置多表关联的方式以及具体的实现细节。 #### 二、多表关联的基本概念 在讨论关联查询之前,我们需要了解在数据库层面,表之间的关系类型。通常情况下,表之间的...

    Yii2.0框架模型多表关联查询示例

    本文实例讲述了Yii2.0框架模型多表关联查询。分享给大家供大家参考,具体如下: 联表查询–hasMany: use app\models\User; $right = Right::findOne(2); //$user = User::find()->where(['right_id' => $right->...

    yii2-save-relations-behavior, 验证并保存相关的Active Record 模型.zip

    yii2-save-relations-behavior, 验证并保存相关的Active Record 模型 Yii2 Active Record 保存关系行为自动验证和保存相关的Active Record 模型。 特性支持 hasMany() 和 hasOne() 关系现有的相关模型一起工作支持...

    yii框架中文文档、yii中文手册教程

    12. **国际化和本地化**:支持多语言的应用程序开发。 13. **拓展和插件**:如何创建和使用第三方扩展,增强框架功能。 通过这些文档,开发者可以深入理解Yii框架的机制,并学会如何有效地利用它来构建强大的Web...

    实例讲解YII2中多表关联的使用方法

    本文对 YII2.0 的多表关联查询做一个简单的介绍。文中通过实例代码介绍的非常详细,下面话不多说,来一起看看详细的介绍: 首先先来说明一下表结构 表结构 现在有订单表、用户表、商品清单表、商品库存表 在YII中...

    Yii 2文件下载

    标题提到的"Yii 2文件下载"可能指的是Yii 2.0框架的安装包或者相关的扩展或示例代码。 在描述中,我们看到“找了好久才找到的Yii2.0”,这可能暗示了Yii 2.0的相关资源并不总是容易找到,尤其对于初学者来说,可能...

    YII 2数据库迁移(Migrations) 使用教程

    在`safeUp()`方法中,可以使用Yii 2提供的数据库操作API来创建数据表,并定义字段。例如: ```php public function safeUp() { $tableOptions = null; if ($this->db->driverName === 'mysql') { // 设置表为...

    Yii权威指南思维导图

    Active Record允许开发者直接与数据库中的表进行交互,通过对象化的操作方式大大简化了数据操作。另外,Yii还提供了CDbConnection和CDbCommand类来支持更底层的SQL操作。 路由管理是Yii框架的重要特性,它决定了URL...

Global site tag (gtag.js) - Google Analytics