成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術教程 ? Yii2.0表關聯查詢實例分析
全站頭部文字 我要出現在這里
Yii2.0表關聯查詢實例分析 699 2024-01-29   

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

你可以使用 ActiveRecord 來進行關聯查詢(比如,從A表讀取數據時把關聯的B表數據也一起讀出來), 在Active Record中,獲取關聯數據可以像訪問主表ActiveRecord對象的屬性(property)一樣簡單。

比如,通過合適的關系聲明,你可以使用 $customer->orders 來獲取一個 Order 對象數組,代表該客戶下的訂單。

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

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

上述代碼中的 yiidbActiveRecord::hasMany() 和 yiidbActiveRecord::hasOne() 是用來建模關系型數據庫中的 一對多 以及 一對一 關聯關系。比如,一個客戶customer有多個訂單orders,而一個訂單擁有或歸屬于一個用戶。兩個方法均接收兩個參數并返回一個 yiidbActiveQuery 對象:

$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 yiidbActiveRecord
{
 public function getBigOrders($threshold = 100)
 {
  return $this->hasMany(Order::className(), ['customer_id' => 'id'])
   ->where('subtotal > :threshold', [':threshold' => $threshold])
   ->orderBy('id');
 }
}

記住 hasMany() 返回對象是一個 yiidbActiveQuery ,因此ActiveQuery的方法都可以被用來定制這個關聯查詢。

通過上述聲明,如果你訪問 $customer->bigOrders, 它將只返回數額大于100的訂單。如果想指定一個不同的限定值,使用如下代碼:

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

注意:關聯方法返回一個 yiidbActiveQuery 實例。如果你以屬性(類property)的方式來訪問它,返回數據是一個 yiidbActiveRecord 實例、或者是ActiveRecord數組或為空(null)。比如, $customer->getOrders() 返回一個 ActiveQuery 實例,而$customer->orders 返回一個 Order 對象數組(或者是一個空數組,如果查詢結果為空)。

中間表關聯查詢

有時候,一些數據表通過中間表(pivot table)關聯在一起。為了聲明這樣的關系,我們可以定制 yiidbActiveQuery 對象,通過調用它的 via() 或 viaTable() 方法。

比如,如果訂單表 order 和商品表 item 通過連接表 order_item關聯,我們可以在 Order 類中聲明 items 關系如下:

class Order extends yiidbActiveRecord
{
 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 yiidbActiveRecord
{
 public function getOrderItems()
 {
  return $this->hasMany(OrderItem::className(), ['order_id' => 'id']);
 }
 public function getItems()
 {
  return $this->hasMany(Item::className(), ['id' => 'item_id'])
   ->via('orderItems');
 }
}

更多關于Yii相關內容感興趣的讀者可查看本站專題:《Yii框架入門及常用技巧總結》、《php優秀開發框架總結》、《smarty模板入門基礎教程》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家基于Yii框架的PHP程序設計有所幫助。



主站蜘蛛池模板: www.douyin.com官网| 卡通图片头像| 快乐读书吧1-6年级推荐书目| 抖音app安装| 749局演员表| 台湾电视台| 无声真相电影免费观看| 喜欢小红帽的原因怎么写| 操蛋视频| 抖 音| alurajenson主演的电影| 澳亚卫视| 护花使者歌词| 张扬导演| 戚薇夫妇现身机场| 小救星小渡| dnf代码大全| 科特·柯本| 倪妮| 87电影| 厕所英雄| 抖音在线观看| 谍变1939电视剧剧情介绍| soldier's heart| 福利视频观看| 九龙城寨在线观看| 永井大| 夜电影| 2024年计划生育家庭特别扶助| 金福南事件始末在线观看高清影评| 出彩中国人撒贝宁精忠报国15分钟| 深流 电视剧| 国昌| 珠江电视台直播 珠江频道| 方谬神探 电视剧| 书柜效果图大全2023款| 孔丽娜个人资料简介| 公共安全教育第一课| 邯郸恋家网| angie faith| 繁星(十)|

!!!站長長期在線接!!!

網站、小程序:定制開發/二次開發/仿制開發等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103