首頁 後端開發 php教程 YII2中關於多表關聯如何操作的實例詳解

YII2中關於多表關聯如何操作的實例詳解

Jul 22, 2017 pm 03:02 PM
yii2 如何 操作

最近工作中遇到了YII2多表關聯的相關問題,發現網上這方面的資料並不多,所以想著自己整理下吧,方便自己在以後需要的時候或者有需要的朋友們參考學習,以下這篇文章主要跟大家介紹了關於YII2中多重表格關聯的使用方法,需要的朋友下面來一起看看吧。

前言

本文對 YII2.0 的多表關聯查詢做一個簡單的介紹。文中透過實例程式碼介紹的非常詳細,下面話不多說,來一起看看詳細的介紹:

#首先先來說明一下表格結構

#表格結構

現在有訂單表、使用者表、商品清單表、商品庫存表

#在YII中,如果想直接關聯其他表進行查詢的話,需要先在模型裡定義它們的關聯

Order


class Order extends \yii\db\ActiveRecord.{
 
 // 关联函数以get+要关联的数据表名来命名
 // 这是获取下订单的客户
 public function getUser(){
  
  // 第一个参数为要关联的子表模型类名,
  // 第二个参数指定 通过子表的user_id,关联主表的usesr_id字段
  // 这里写清楚点大概意思就是User.user_id => Order.user_id
 return $this->hasMany(User::className(), ['user_id' => 'user_id']);
 }
}
登入後複製

1、hasMany、hasOne使用

Yii2中的表格之間的關聯有2種,它們用來指定兩個模型之間的關聯。

      ●一對一: hasMany ●一對一:hasOne

##      ●回傳結果:這兩個方法的回傳結果都為yiidbActiveQuery(如果你想最後回傳的是標準陣列形式,記得加上asArray()參數)


      ●第一個參數:所關聯的模型的類別名稱。


      ●第二個參數:是一個陣列,其中鍵為所關聯的模型中的屬性,值為目前模型中的屬性。


關聯的使用

#現在我們來嘗試取得一個訂單


//获取订单信息
$order = Order::findOne(1);
//根据订单信息获取到用户信息
$user = $order->user;
登入後複製

當然你可以選擇使用with方法,這樣看起來簡潔一些,其中with的參數為關係的名稱,也就在model裡面定義的getUser中的user.


//返回订单信息(包括用户信息)
$order = Order::find(1)->with('user');
//或者
$order = Order::find(1)->getUser();
登入後複製

上面的程式碼會產生並執行如下的sql語句


SELECT * FROM order WHERE id=1;
SELECT * FROM user  WHERE user.user_id=order.user_id;
登入後複製

從上面可以看出存取一個關聯的時候有兩種方法

       ●如果以函數的方式調用,會傳回一個ActiveQuery 物件($customer->getOrders()->all())

#   方式調用,會直接返回模型的結果($customer->orders)


#關聯結果快取

如果這時order表發生了改變,我們希望再次查詢的話


$user = $order->user;
登入後複製

再次得到訂單的時候你會發現沒有變化。原因是只會在第一次執行$order->user的時候才會去資料庫裡面查詢,然後會把結果快取起來,以後查詢的時候都不會再執行sql。

那麼如果你想再執行sql如何做呢?可以執行


//先释放缓存
unset($order->user);
$order->user;
登入後複製

跨表查詢
##下面重點來了!透過上面表結構的圖可以看到,User表和Order_goods表示沒有直接關聯的,那麼如果我們想根據使用者資訊來找出這個使用者買了哪些商品的話,就勢必需要透過Order表去關聯兩張表。那該怎麼做呢?首先還是model層。因為我們是依照使用者去查,所以到User的model層去定義關聯。

User

public function getOrder() {
 return $this->hasMany(Order::className(), ['user_id' => 'user_id']);
}
 
public function getOrderGoods() {
 return $this->hasMany(OrderGoods::className(), ['order_id' => 'order_id'])->
  via('order');
}
登入後複製

#這裡注意:getOrderGoods中的第二個order_id是指getOrder關聯的Order中的order_id,第一個order_id是指OrderGoods中的order_id。 但是!我們還有最簡單的方法,就是使用SQL語句囉!

$map = 'select
  user.name,
  order.id,
  order_goods.goods_id,
  goods.goods_name,
  stock.stock_count
  from user
  LEFT JOIN order   ON order.user_id = user.user_id
  LEFT JOIN order_goods ON order_goods.order_id = order.order_id
  LEFT JOIN goods   ON goods.goods_id = order_goods.goods_id
  LEFT JOIN stock   ON stock.goods_id = goods.goods_id';

$list1 = Article::findBySql($map)->asArray()->all();
登入後複製

這樣基本上就是整個關聯部分了

#總結##

以上是YII2中關於多表關聯如何操作的實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

PyCharm使用教學:詳細指引你執行操作 PyCharm使用教學:詳細指引你執行操作 Feb 26, 2024 pm 05:51 PM

PyCharm是一款非常受歡迎的Python整合開發環境(IDE),它提供了豐富的功能和工具,使得Python開發變得更有效率和便利。本文將為大家介紹PyCharm的基本操作方法,並提供具體的程式碼範例,幫助讀者快速入門並熟練操作工具。 1.下載安裝PyCharm首先,我們需要前往PyCharm官網(https://www.jetbrains.com/pyc

什麼是 sudo,為什麼它如此重要? 什麼是 sudo,為什麼它如此重要? Feb 21, 2024 pm 07:01 PM

sudo(超級使用者執行)是Linux和Unix系統中的關鍵指令,允許一般使用者以root權限執行特定指令。 sudo的功能主要體現在以下幾個方面:提供權限控制:sudo透過授權使用者以臨時方式取得超級使用者權限,從而實現了對系統資源和敏感操作的嚴格控制。普通用戶只能在需要時透過sudo獲得臨時的特權,而不需要一直以超級用戶登入。提升安全性:透過使用sudo,可以避免在常規操作中使用root帳號。使用root帳戶進行所有操作可能會導致意外的系統損壞,因為任何錯誤或不小心的操作都將具有完全的權限。而

win10開機密碼忘記按F2怎麼操作 win10開機密碼忘記按F2怎麼操作 Feb 28, 2024 am 08:31 AM

想必很多的用戶家裡都有那麼幾台不用的電腦,因為長時間不用完全忘了開機密碼,於是想知道一下,忘記密碼要怎麼操作呢?那就一起來看看吧。 win10開機密碼忘記按F2怎麼操作1、按下電腦的電源鍵,然後開機時按下F2(不同電腦品牌進入bios的按鍵也不同)。 2.在bios介面中,找到security選項(不同品牌電腦的位置可能有所不同)。一般都在頂部的設定選單中。 3.然後找到SupervisorPassword選項並且點選。 4.這時候用戶就可以看到自己的密碼了,同時找到旁邊的Enabled切換為Dis

Linux Deploy的操作步驟及注意事項 Linux Deploy的操作步驟及注意事項 Mar 14, 2024 pm 03:03 PM

LinuxDeploy的操作步驟及注意事項LinuxDeploy是一款強大的工具,可協助使用者在Android裝置上快速部署各種Linux發行版,讓使用者在行動裝置上體驗完整的Linux系統。本文將詳細介紹LinuxDeploy的操作步驟以及注意事項,同時提供具體的程式碼範例,幫助讀者更好地使用此工具。操作步驟:安裝LinuxDeploy:首先在

如何在 iPhone 15 Pro 和 15 Pro Max 上停用操作按鈕 如何在 iPhone 15 Pro 和 15 Pro Max 上停用操作按鈕 Nov 07, 2023 am 11:17 AM

Apple在iPhone15Pro和15ProMax中帶來了一些Pro獨有的硬體功能,吸引了所有人的注意。我們正在談論鈦合金框架、時尚的設計、全新的A17Pro晶片組、令人興奮的5倍長焦鏡頭等等。在iPhone15Pro機型添加的所有花里胡哨的功能中,操作按鈕仍然是一個突出和突出的功能。毋庸置疑,它是在iPhone上啟動操作的有用補充。也就是說,您可能會不小心按住“操作”按鈕並無意中觸發功能。坦白說,這很煩人。要避免這種情況,您應該停用iPhone15Pro和15ProMax上的操作按鈕。讓

華為Mate60 Pro截圖操作步驟分享 華為Mate60 Pro截圖操作步驟分享 Mar 23, 2024 am 11:15 AM

隨著智慧型手機的普及,螢幕截圖功能成為日常使用手機的必備技能之一。華為Mate60Pro作為華為公司的旗艦手機之一,其截圖功能自然也備受用戶關注。今天,我們就來分享華為Mate60Pro手機的截圖操作步驟,讓大家能夠更方便地進行截圖操作。首先,華為Mate60Pro手機提供了多種截圖方式,可以依照個人習慣選擇適合自己的方式來操作。以下詳細介紹幾種常用的截

CSS網頁滾動監聽:監聽網頁滾動事件並執行對應的操作 CSS網頁滾動監聽:監聽網頁滾動事件並執行對應的操作 Nov 18, 2023 am 10:35 AM

CSS網頁滾動監聽:監聽網頁滾動事件並執行對應的操作隨著前端技術的不斷發展,網頁的效果和互動也越來越豐富多樣。其中,滾動監聽是一種常見的技術,可以實現在使用者滾動網頁時,根據滾動位置執行一些特效或操作。一般來說,滾動監聽可以透過JavaScript來實現。但是,在某些情況下,我們也可以透過純CSS來實現滾動監聽的效果。本文將介紹如何透過CSS來實現網頁的滾動

自訂操作按鈕:探索iPhone 15 Pro的個人化設置 自訂操作按鈕:探索iPhone 15 Pro的個人化設置 Sep 24, 2023 pm 03:05 PM

蘋果的iPhone15Pro和iPhone15ProMax引入了一個新的可編程動作按鈕,取代了音量按鈕上方的傳統響鈴/靜音開關。繼續閱讀以了解「操作」按鈕的功能,以及如何自訂。蘋果iPhone15Pro型號上全新的動作按鈕取代了啟動Ring和Silent的傳統iPhone開關。預設情況下,新按鈕仍會透過長按啟動這兩個功能,但您也可以讓長按執行一系列其他功能,包括快速存取相機或手電筒、啟動語音備忘錄、對焦模式、翻譯和放大鏡等輔助功能。您還可以將其與單一快捷方式相關聯,從而開闢大量其他可能

See all articles