首頁 >後端開發 >php教程 >對於Yii2.0表關聯查詢的分析

對於Yii2.0表關聯查詢的分析

不言
不言原創
2018-06-15 14:36:062620瀏覽

這篇文章主要介紹了Yii2.0表關聯查詢的方法,結合實例形式分析了Yii中關聯查詢的實現方法與相關使用技巧,需要的朋友可以參考下

本文實例講述了Yii2.0表關聯查詢的方法。分享給大家供大家參考,具體如下:

你可以使用ActiveRecord 來進行關聯查詢(比如,從A表讀取資料時把關聯的B表資料也一起讀出來), 在Active Record中,取得關聯資料可以像存取主表ActiveRecord物件的屬性(property)一樣簡單。

例如,透過適當的關係聲明,你可以使用 $customer->orders 來取得一個 Order 物件數組,代表該客戶下的訂單。

要聲明一個關係(relation),定義一個getter方法,該方法返回一個 yii\db\ActiveQuery 對象,擁有關聯上下文信息,這樣將只查詢符合條件的相關數據。例如:

class Customer extends \yii\db\ActiveRecord
{
 public function getOrders()
 {
  // Customer has_many Order via Order.customer_id -> id
  return $this->hasMany(Order::className(), ['customer_id' => 'id']);
 }
}
class Order extends \yii\db\ActiveRecord
{
 // Order has_one Customer via Customer.id -> customer_id
 public function getCustomer()
 {
  return $this->hasOne(Customer::className(), ['id' => 'customer_id']);
 }
}

上述程式碼中的yii\db\ActiveRecord::hasMany() 和yii\db\ActiveRecord::hasOne() 是用來建模關係型資料庫中的一對多以及一對一關聯關係。例如,一個客戶customer有多個訂單orders,而一個訂單擁有或歸屬於一個使用者。兩個方法均接收兩個參數並傳回一個 yii\db\ActiveQuery 物件:

#$class: 關聯模型的類別名稱。

$link: 兩個表之間的列關聯。這得是一個數組。陣列元素的鍵是 $class 對應表的列名稱,而陣列元素的值是目前宣告類別的列名稱。依據表外鍵關聯來定義這些關係是一個好的程式設計實踐。

完成上述聲明後,就可以透過定義對應的getter方法來像存取物件屬性一樣取得關聯資料:

// get the orders of a customer
$customer = Customer::findOne(1);
$orders = $customer->orders; // $orders is an array of Order objects

上述程式碼在幕後實際執行如下兩個SQL查詢,分別對應上述兩行程式碼:

SELECT * FROM customer WHERE id=1;
SELECT * FROM order WHERE customer_id=1;

提示:如果你再造訪$customer->orders ,並不會重複執行上述第2行SQL查詢。這條查詢語句只在表達式第一次被存取時才執行。後續的存取將直接傳回內部緩衝資料。如果你想重新執行查詢,只需要先呼叫unset來清除快取:

unset($customer->orders);.

有時候,你可能想要傳遞參數給關聯查詢來限定查詢條件。例如只想讀取超過指定金額的大額訂單,而不是所有訂單。為此,可以使用以下getter方法來宣告一個bigOrders 關係:

class Customer extends \yii\db\ActiveRecord
{
 public function getBigOrders($threshold = 100)
 {
  return $this->hasMany(Order::className(), ['customer_id' => 'id'])
   ->where('subtotal > :threshold', [':threshold' => $threshold])
   ->orderBy('id');
 }
}

記住 hasMany() 傳回物件是一個yii\db\ActiveQuery ,因此ActiveQuery的方法都可以被用來客製化這個關聯查詢。

透過上述聲明,如果你造訪 $customer->bigOrders, 它將只回傳數額大於100的訂單。如果想要指定一個不同的限定值,使用以下程式碼:

$orders = $customer->getBigOrders(200)->all();

注意:關聯方法傳回一個 yii\db\ActiveQuery 實例。如果你以屬性(類別property)的方式來存取它,回傳資料是一個 yii\db\ActiveRecord 實例、或是ActiveRecord陣列或為空(null)。例如, $customer->getOrders() 傳回一個 ActiveQuery 實例,而$customer->orders 傳回一個 Order 物件陣列(或是空數組,如果查詢結果為空)。

中間表關聯查詢

有時候,一些資料表透過中間表(pivot table)關聯在一起。為了宣告這樣的關係,我們可以自訂 yii\db\ActiveQuery 對象,透過呼叫它的 via() 或 viaTable() 方法。

例如,如果訂單表order 和商品表item 透過連接表order_item關聯,我們可以在Order 類別中宣告items 關係如下:

class Order extends \yii\db\ActiveRecord
{
 public function getItems()
 {
  return $this->hasMany(Item::className(), ['id' => 'item_id'])
   ->viaTable('order_item', ['order_id' => 'id']);
 }
}

via() 方法和viaTable() 類似,不過第一個參數是在目前ActiveRecord類別中宣告的一個關係(relation)名,而不是中間表的名稱。例如,上述 items 關係也可以用下面的方法來聲明:

class Order extends \yii\db\ActiveRecord
{
 public function getOrderItems()
 {
  return $this->hasMany(OrderItem::className(), ['order_id' => 'id']);
 }
 public function getItems()
 {
  return $this->hasMany(Item::className(), ['id' => 'item_id'])
   ->via('orderItems');
 }
}

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!

相關推薦:

Yii中表單用法實例

關於YII關聯查詢的解析

以上是對於Yii2.0表關聯查詢的分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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