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

 更新时间:2020-01-24 13:00:36   作者:佚名   我要评论(0)

本文实例讲述了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程序设计有所帮助。

您可能感兴趣的文章:

  • Laravel 关联模型-关联新增和关联更新的方法
  • Laravel关联模型中过滤结果为空的结果集(has和with区别)
  • laravel学习教程之关联模型
  • Laravel5.1 框架模型多态关联用法实例分析
  • Laravel等框架模型关联的可用性浅析
  • Laravel Eloquent分表方法并使用模型关联的实现
  • Laravel 模型关联基础教程详解
  • Laravel5.1 框架模型一对一关系实现与使用方法实例分析
  • Laravel5.1 框架模型查询作用域定义与用法实例分析
  • Laravel5.1 框架模型创建与使用方法实例分析
  • Laravel5.1 框架关联模型之后操作实例分析

相关文章

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

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

    本文实例讲述了Laravel5.1 框架模型远层一对多关系。分享给大家供大家参考,具体如下: 远层一对多我们可以通过一个例子来充分的了解它: 每一篇文章都肯定有并且只
    2020-01-24
  • Laravel5.1 框架文件管理操作实例分析

    Laravel5.1 框架文件管理操作实例分析

    本文实例讲述了Laravel5.1 框架文件管理操作。分享给大家供大家参考,具体如下: Laravel提供了一套很好用的文件系统 方便于管理文件夹和文件,支持Amazon S3和Rack
    2020-01-24
  • Laravel5.1 框架模型多态关联用法实例分析

    Laravel5.1 框架模型多态关联用法实例分析

    本文实例讲述了Laravel5.1 框架模型多态关联用法。分享给大家供大家参考,具体如下: 什么是多态关联? 一个例子你就明白了:好比如说评论 它可以属于视频类 也可以
    2020-01-24
  • Laravel5.1 框架关联模型之后操作实例分析

    Laravel5.1 框架关联模型之后操作实例分析

    本文实例讲述了Laravel5.1 框架关联模型之后操作。分享给大家供大家参考,具体如下: 之前写过关于模型关联的笔记,但是模型关联好后的一些使用没有介绍,今天补上
    2020-01-24
  • laravel框架学习记录之表单操作详解

    laravel框架学习记录之表单操作详解

    本文实例讲述了laravel框架学习记录之表单操作。分享给大家供大家参考,具体如下: 1、MVC数据流动 拿到一个laravel项目最基本的是弄清楚它的页面请求、数据流动是怎
    2020-01-24
  • Laravel5.1 框架分页展示实现方法实例分析

    Laravel5.1 框架分页展示实现方法实例分析

    本文实例讲述了Laravel5.1 框架分页展示实现方法。分享给大家供大家参考,具体如下: Laravel为我们提供了一套分页的逻辑,我们无需自己实现分页逻辑,只需要执行几
    2020-01-24
  • PHP变量作用域(全局变量&局部变量)&global&static关键字用法实例分析

    PHP变量作用域(全局变量&局部变量)&global&static关键字用法实例分析

    本文实例讲述了PHP变量作用域(全局变量&局部变量)&global&static关键字用法。分享给大家供大家参考,具体如下: 我们知道,变量呢,其实就相当于我们用来储存信息
    2020-01-24
  • thinkphp调用sqlserver储存过程返回多个结果集

    thinkphp调用sqlserver储存过程返回多个结果集

    首先安装扩展 windows 分为两个步骤 找到对应自己PHP版本的pdo扩展,下载解压出来,并且在php.ini里面启用扩展,需要注意的问题是php版本以及是否为安全版本
    2020-01-24
  • Laravel框架路由与MVC实例详解

    Laravel框架路由与MVC实例详解

    本文实例讲述了Laravel框架路由与MVC。分享给大家供大家参考,具体如下: 1、路由 路由的作用就是将用户的不同url请求转发给相应的程序进行处理,laravel的路由定义
    2020-01-24
  • Laravel5.1 框架登录和注册实现方法详解

    Laravel5.1 框架登录和注册实现方法详解

    本文实例讲述了Laravel5.1 框架登录和注册实现方法。分享给大家供大家参考,具体如下: 关于登录和注册 Laravel自带了一套组件实现了这一功能,我们只需要实现简单的
    2020-01-24

最新评论