热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

ThinkPHP关联模型操作实例

使用relation方法进行关联操作,relation方法不但可以启用关联还可以控制局部关联操作,实现了关联操作一切尽在掌握之中。

通常我们所说的关联关系包括下面三种:

    ◇ 一对一关联   : ONE_TO_ONE , 包括 HAS_ONE  和  BELONGS_TO 
    ◇ 一对多关联   : ONE_TO_MANY , 包括 HAS_MANY  和  BELONGS_TO
    ◇ 多对多关联   : MANY_TO_MANY

关联定义

数据表的关联 CURD 操作,目前支持的关联关系包括下面四种:HAS_ONE 、 BELONGS_TO 、 HAS_MANY 、 MANY_TO_MANY 。

一个模型根据业务模型的复杂程度可以同时定义多个关联,不受限制,所有的关联定义都统一在模型类的 $_link 成员变量里面定义,并且可以支持动态定义。要支持关联操作,模型类必须继承 RelationModel 类,关联定义的格式是:

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

HAS_ONE 关联方式的定义:

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

    mapping_type 关联类型,这个在 HAS_ONE 关联里面必须使用 HAS_ONE 常量定义。
    class_name 要关联的模型类名
    mapping_name 关联的映射名称,用于获取数据用
    foreign_key 关联的外键名称
    condition 关联条件
    mapping_fields 关联要查询的字段
    as_fields 直接把关联的字段值映射成数据对象中的某个字段

BELONGS_TO 关联方式的定义:

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

    class_name 要关联的模型类名
    mapping_name 关联的映射名称,用于获取数据用
    foreign_key 关联的外键名称
    mapping_fields 关联要查询的字段
    condition 关联条件
    parent_key 自引用关联的关联字段
    as_fields 直接把关联的字段值映射成数据对象中的某个字段

HAS_MANY 关联方式的定义:

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

    class_name 要关联的模型类名
    mapping_name 关联的映射名称,用于获取数据用
    foreign_key 关联的外键名称
    parent_key 自引用关联的关联字段
    condition 关联条件
    mapping_fields 关联要查询的字段
    mapping_limit 关联要返回的记录数目
    mapping_order 关联查询的排序

MANY_TO_MANY 关联方式的定义:

    "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 要关联的模型类名
    mapping_name 关联的映射名称,用于获取数据用
    foreign_key 关联的外键名称
    relation_foreign_key 关联表的外键名称
    mapping_limit 关联要返回的记录数目
    mapping_order 关联查询的排序
    relation_table 多对多的中间关联表名称

关联查询

使用 relation 方法进行关联操作, relation 方法不但可以启用关联还可以控制局部关联操作,实现了关联操作一切尽在掌握之中。

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

输出 $user 结果可能是类似于下面的数据:

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

关联写入

    $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);

这样就会自动写入关联的 Profile 数据。

关联更新

    $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);

关联删除

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


推荐阅读
  • 在跨浏览器开发中,一个常见的问题是关于如何在鼠标悬停时显示图片提示信息。本文深入探讨了 IE 浏览器对 IMG 元素 alt 属性的特殊处理,并提供了最佳实践建议。 ... [详细]
  • 反向投影技术主要用于在大型输入图像中定位特定的小型模板图像。通过直方图对比,它能够识别出最匹配的区域或点,从而确定模板图像在输入图像中的位置。 ... [详细]
  • 本文由杨勇和思远于2012年12月27日撰写,主要探讨了如何使用PHP进行网页内容抓取,特别是针对字符较多的网站。文章详细介绍了正则表达式失效的原因,并提供了优化方法,同时展示了如何抓取淘宝服饰栏、天气信息以及IP地址对应的地理位置。 ... [详细]
  • Python第三方库安装的多种途径及注意事项
    本文详细介绍了Python第三方库的几种常见安装方法,包括使用pip命令、集成开发环境(如Anaconda)以及手动文件安装,并提供了每种方法的具体操作步骤和适用场景。 ... [详细]
  • 解决Anaconda安装TensorFlow时遇到的TensorBoard版本问题
    本文介绍了在使用Anaconda安装TensorFlow时遇到的“Could not find a version that satisfies the requirement tensorboard”错误,并提供详细的解决方案,包括创建虚拟环境和配置PyCharm项目。 ... [详细]
  • 查找最小值的操作是很简单的,只需要从根节点递归的遍历到左子树节点即可。当遍历到节点的左孩子为NULL时,则这个节点就是树的最小值。上面的树中,从根节点20开始,递归遍历左子 ... [详细]
  • 本文详细介绍了如何在PHP中使用serialize()和unserialize()函数,以及它们在数据传输和存储中的应用。 ... [详细]
  • 在使用STM32Cube进行定时器配置时,有时会遇到延时不准的问题。本文探讨了可能导致延时不准确的原因,并提供了解决方法和预防措施。 ... [详细]
  • 本文探讨了大数据测试的最新进展,涵盖了数据采集、处理和分析的技术和方法。 ... [详细]
  • 阿里云ecs怎么配置php环境,阿里云ecs配置选择 ... [详细]
  • 本文介绍了MindManager在项目管理中的强大功能,特别是其内置的甘特图工具。通过该工具,用户可以轻松创建和管理项目计划,优化任务分配,并与其他软件无缝集成。 ... [详细]
  • 深入理解Lucene搜索机制
    本文旨在帮助读者全面掌握Lucene搜索的编写步骤、核心API及其应用。通过详细解析Lucene的基本查询和查询解析器的使用方法,结合架构图和代码示例,带领读者深入了解Lucene搜索的工作流程。 ... [详细]
  • 本文详细介绍了如何在《仁王》游戏中配置笔记本电脑的独立显卡,确保游戏性能优化。包括A卡和N卡的具体设置步骤。 ... [详细]
  • 探索厦门的地道美食
    厦门不仅以其美丽的自然风光和丰富的文化底蕴吸引着游客,更以种类繁多、风味独特的美食闻名。本文将带您了解厦门的特色小吃,让您在旅行中不仅能欣赏美景,还能大饱口福。 ... [详细]
  • ThinkPad USB 硬盘启动 Ubuntu 系统的详细步骤
    本文介绍如何通过USB硬盘在联想ThinkPad上启动Ubuntu系统,包括BIOS设置和启动优先级调整。 ... [详细]
author-avatar
学海无涯
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有