Laravel5.1 框架模型远层一对多关系实例分析

 更新时间:2020年01月09日 10:28:19   作者:Sky_sunkang  
这篇文章主要介绍了Laravel5.1 框架模型远层一对多关系,结合实例形式分析了laravel5.1框架模型远层一对多关系相关原理、实现方法与操作注意事项,需要的朋友可以参考下

本文实例讲述了Laravel5.1 框架模型远层一对多关系。分享给大家供大家参考,具体如下:

远层一对多我们可以通过一个例子来充分的了解它:

每一篇文章都肯定有并且只有一个发布者 发布者可以有多篇文章,这是一个一对多的关系。一个发布者可以来自于一个国家 但是一个国家可以有多个发布者,这又是一个一对多关系,那么 这其中存在一个远层的一对多就是"国家和文章的关系"。国家表可以通过发布者表远层关联到文章表。

1 实现远层一对多关系

1.1 文章表结构

  public function up()
  {
    Schema::create('articles', function (Blueprint $table) {
      $table->increments('id');
      $table->string('title');
      $table->text('body');
      $table->integer('user_id');
      $table->timestamps();
    });
  }

1.2 在users表中添加一列

  public function up()
  {
    Schema::table('users', function (Blueprint $table) {
      $table->integer('country_id');
    });
  }
  public function down()
  {
    Schema::table('users', function (Blueprint $table) {
      $table->dropColumn('country_id');
    });
  }

1.3 国家表结构

  public function up()
  {
    Schema::create('countries', function (Blueprint $table) {
      $table->increments('id');
      $table->string('name');
      $table->timestamps();
    });
  }

1.4 编写一对多关系

首先是Country和User的关系:

Country模型:

  public function users()
  {
    return $this->hasMany(User::class);
  }

User模型:

  public function country()
  {
    return $this->belongsTo(Country::class);
  }

然后是User和Article的关系:

User模型:

  public function articles()
  {
    return $this->hasMany(Article::class);
  }

Article模型:

  public function user()
  {
    return $this->belongsTo(User::class);
  }


1.5 访问远程一对多关系

这是今天的主要内容,实现Country可远层查找到Article:

  public function articles()
  {
    /**
     * 建议第一个和第二个参数写全,第三个第四个参数可省略使用默认(如果默认的没问题)。
     */
    return $this->hasManyThrough(Article::class, User::class, 'country_id', 'user_id');
  }

更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。

相关文章

  • 详解阿里云视频直播PHP-SDK接入教程

    详解阿里云视频直播PHP-SDK接入教程

    这篇文章主要介绍了阿里云视频直播PHP-SDK接入教程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • php实现生成带二维码图片并强制下载功能

    php实现生成带二维码图片并强制下载功能

    这篇文章主要介绍了php生成带二维码图片并强制下载实现代码,需要的朋友可以参考下
    2018-02-02
  • php中session使用示例

    php中session使用示例

    这篇文章主要介绍了php中session使用示例,需要的朋友可以参考下
    2014-03-03
  • Smarty缓存机制实例详解【三种缓存方式】

    Smarty缓存机制实例详解【三种缓存方式】

    这篇文章主要介绍了Smarty缓存机制,结合实例形式详细分析了Smarty全局缓存、部分缓存及局部缓存三种缓存实现方式,并附带说明了Smarty清除缓存的实现方式,需要的朋友可以参考下
    2019-07-07
  • php IIS日志分析搜索引擎爬虫记录程序

    php IIS日志分析搜索引擎爬虫记录程序

    由于最近比较忙,代码写得不怎么规范,界面也没有怎么美化,大家先用着吧,以后增加新功能会第一时间发布给大家!
    2008-08-08
  • PHP中的运算符使用示例详细指南

    PHP中的运算符使用示例详细指南

    这篇文章主要为大家介绍了PHP中的运算符使用示例详细指南,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • Yii框架实现对数据库的CURD操作示例

    Yii框架实现对数据库的CURD操作示例

    这篇文章主要介绍了Yii框架实现对数据库的CURD操作,结合实例形式分析了Yii框架连接数据库与CURD增删改查等常见操作技巧,需要的朋友可以参考下
    2019-09-09
  • php加密解密实用类分享

    php加密解密实用类分享

    加密和解密是一项常规任务,这里介绍一个加解密类。如果你想在用户忘记密码时为他或她找回原来的密码,那么这个类是个好用的工具
    2014-01-01
  • tp5(thinkPHP5)框架实现多数据库查询的方法

    tp5(thinkPHP5)框架实现多数据库查询的方法

    这篇文章主要介绍了tp5(thinkPHP5)框架实现多数据库查询的方法,结合实例形式分析了thinkPHP5框架多数据库查询的相关配置、初始化及调用相关操作技巧,需要的朋友可以参考下
    2019-01-01
  • Laravel利用gulp如何构建前端资源详解

    Laravel利用gulp如何构建前端资源详解

    Gulp 是一个自动化工具,前端开发者可以使用它来处理常见任务,下面这篇文章主要给大家介绍了关于Laravel利用gulp如何构建前端资源的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧
    2018-06-06

最新评论