Laravel5.1 框架關聯模型之后操作實例分析

 更新時間:2020-01-24 13:00:35   作者:佚名   我要評論(0)

本文實例講述了Laravel5.1 框架關聯模型之后操作。分享給大家供大家參考,具體如下:
之前寫過關于模型關聯的筆記,但是模型關聯好后的一些使用沒有介紹,今天補上

本文實例講述了Laravel5.1 框架關聯模型之后操作。分享給大家供大家參考,具體如下:

之前寫過關于模型關聯的筆記,但是模型關聯好后的一些使用沒有介紹,今天補上

1 寫入關聯模型

1.1 使用Save方法(一對多)

我們準備了兩個模型:Post和Comment。 它們的關系是一對多關系。現在我們要創建新的Comment到Post:

  public function getIndex()
  {
    // 創建一個comment模型
    $comment = new Comment(['title'=> 'comment1', 'content'=> 'content1']);
    // 取到post模型
    $post = Post::findOrFail(1);
    $post->comments()->save($comment);
  }

這樣創建呢 Comment的post_id 列會自動填充。

我們還可以批量的添加下屬模型,相當方便~:

  public function getIndex()
  {
    // 創建一個comment模型
    $comment2 = new Comment(['title'=> 'comment2', 'content'=> 'content2']);
    $comment3 = new Comment(['title'=> 'comment3', 'content'=> 'content3']);
    // 取到post模型
    $post = Post::findOrFail(1);
    $post->comments()->saveMany([$comment2, $comment3]);
  }

1.2 使用Save方法(多對多)

準備一個Tag模型,它和Post模型多對多的關系,別忘了生成中間表哦:

  public function getIndex()
  {
    // 創建文章
    $post = new Post();
    $post->title = 'Laravel Model';
    $post->sub_title = '模型的詳細使用';
    $post->content = 'content...';
    // 添加到Tag
    $tag = Tag::findOrFail(1);
    $tag->posts()->save($post);
  }

↑ 我們無需管中間表,Laravel會自動為我們填充中間表的關聯屬性,

多對多的save方法中是允許我們傳入第二個參數的。第二個參數是中間表的屬性數組:

  public function getIndex()
  {
    // 創建文章
    $post = new Post();
    $post->title = 'Laravel Model';
    $post->sub_title = '模型的詳細使用';
    $post->content = 'content...';
    // 添加到Tag
    $tag = Tag::findOrFail(1);
    // 當創建時需要填充中間表的額外列時,可以傳遞第二個參數。
    // 這里我們的中間表有個expires列,添加關聯時可以同時設置。
    $tag->posts()->save($post, ['expires' => true]);
  }

1.3 使用Create方法

Create方法是一種批量填充模式 所以記得在Model中設置白/黑名單,它和save的唯一區別就是 只能傳遞數組、不能將一個模型實例傳入。

  public function getIndex()
  {
    $tag = Tag::findOrFail(1);
    // create方法同樣也可以接受第二個參數。
    $tag->posts()->create([
      'title' => 'Laravel Model',
      'sub_title' => 'Laravel 模型關聯的使用',
      'content' => 'content...'
    ], ['expires' => true]);
  }

2 更新關聯關系

2.1 更新一個關系(除多對多適用)

重要的事情需要重復一遍:associate方法只不對多對多關系適用。而且使用時要用下方模型 調用associate方法,將下方模型更新到新的上方模型

  public function getIndex()
  {
    $post = Post::findOrFail(1);
    $comment = Comment::findOrFail(1);
    $comment->post()->associate($post);
    $comment->save();
  }

2.2 移除一個關系(除多對多適用)

重要的事情需要重復一遍:dissociate方法只不對多對多關系適用。而且使用時要用下方模型 調用dissociate方法,將下方模型從上方模型的關聯中移除。此外此方法執行后會將下方模型的外鍵id至為0

  public function getIndex()
  {
    $post = Post::findOrFail(1);
    $comment = Comment::findOrFail(1);
    $comment->post()->dissociate($post);
    $comment->save();
  }

2.3 追加一個關系(多對多關系)

一定要看注釋,一定要看注釋,一定要看注釋,注釋解釋的很清楚,你可能心中有疑問 這個追加關系和之間創建關系有什么區別?你可能忽視了一個細節:創建添加時 是新建一個模型后加入關聯,而attach方法是:追加一個已經存在的模型進行關聯。

  public function getIndex()
  {
    // 取到ID為3的文章 這篇文章與id為1的tag有關系。
    $post = Post::findOrFail(3);
    // attach方法的參數只需要傳遞id(整型)即可,中間表會自動更新。
    // 注意:attach的功能是追加一個關系并非更新,執行以下代碼后 該post會與id為3和2的tag有關系。
    $post->tags()->attach(2);
    $post->save();
  }

當追加關系時同樣也可以將一個中間表數據加入第二個參數,以此更新中間表的其他列。

  public function getIndex()
  {
    // 取到ID為3的文章 這篇文章與id為1的tag有關系。
    $post = Post::findOrFail(3);
    // attach方法的參數只需要傳遞id(整型)即可,中間表會自動更新。
    // 注意:attach的功能是追加一個關系并非更新,執行以下代碼后 該post會與id為3和2的tag有關系。
    $post->tags()->attach(2, ['expires' => true]);
  }

批量追加:

  public function getIndex()
  {
    $post = Post::findOrFail(3);
    // 第一個參數也可以接收一個數組。
    $post->tags()->attach([2, ['expires' => true], 4, 6]);
  }

2.4 卸載一個關系(多對多關系)

detach方法于attach方法相反,detach方法會將關聯關系刪除

  public function getIndex()
  {
    $post = Post::findOrFail(3);
    $post->tags()->detach(1);
  }

批量卸載:

  public function getIndex()
  {
    $post = Post::findOrFail(3);
    $post->tags()->detach([1, 3, 5]);
  }

2.5 同步關系

同步關系可謂是非常方便,具體的看注釋吧,寫的很清楚:

  public function getIndex()
  {
    // 取出id為2的tag,此時它只和id為3的post有關聯。
    $tag = Tag::findOrFail(2);
    // 同步:傳入一個id數組,存在于此數組的id都會被追加關系,而不在此數組中的id模型關聯 都會被移除。
    $tag->posts()->sync([2, 4, 5]);
  }

注意:sync方法也可以傳入第二個參數,也是數組類型 以便更新中間表中的其他列。由于語法跟前面幾個方法一樣,就不在重復寫了。

更多關于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
  • 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
  • PHP高級編程之消息隊列原理與實現方法詳解

    PHP高級編程之消息隊列原理與實現方法詳解

    本文實例講述了PHP高級編程之消息隊列原理與實現方法。分享給大家供大家參考,具體如下: 1. 什么是消息隊列 消息隊列(英語:Message queue)是一種進程間通信或同
    2020-01-24
  • 正版phpstorm免費激活步驟教程詳解

    正版phpstorm免費激活步驟教程詳解

    Phpstorm是大多數PHP程序員們愛不釋手的一款編碼的集成開發工具。它支持所有PHP語言功能, 提供最優秀的代碼補全、重構、實時錯誤預防等等功能。但是對于一些php新手
    2020-01-24
  • Yii 實現數據加密和解密的示例代碼

    Yii 實現數據加密和解密的示例代碼

    在Yii中又很多的數據我們不能夠以明文進行存儲和展示,例如密碼和一些比較重要的文件信息,這時候我們都需要我們對這些信息進行加密 一:對密碼進行加密和驗證客戶端
    2020-01-24

最新評論

老快3投注技巧 怎样理财收益最大 广西11选五走势图一定牛 万豪国际棋牌游戏下载 今天的3d图谜汇总九 股票投资报告 云南快乐十分在线投注 一分快三下载安装 期货配资玩法 云南快乐十分走势图 今日股票不开盘吗 广西快三出0324011开奖结果 三明商品期货配资 体彩网31选7都是图 快乐双彩分析开奖图 天津炒股配资平台 十一选五的湖北