亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

Yii2.0表關聯查詢實例分析

2024-05-04 23:48:20
字體:
來源:轉載
供稿:網友

本文實例講述了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'); }}

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


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩激情网| 日韩免费精品视频| 亚洲一区二区在线| 国内精品国产三级国产在线专| 亚洲图片欧美午夜| 日韩精品在线视频观看| 欧美成人激情视频免费观看| 91精品国产九九九久久久亚洲| 日韩精品小视频| 色哟哟亚洲精品一区二区| 久久视频中文字幕| 亚洲欧美日韩天堂| 91在线免费视频| 国产午夜精品全部视频播放| 欧美性猛交xxxx乱大交极品| 亚洲香蕉av在线一区二区三区| 欧美成年人视频| 久久综合免费视频| 韩国视频理论视频久久| 日韩中文字幕在线观看| 亚洲成人激情视频| 国产精品爽爽爽爽爽爽在线观看| 国产精品香蕉在线观看| 国产精品日韩欧美综合| 亚洲aⅴ男人的天堂在线观看| zzijzzij亚洲日本成熟少妇| 亚洲成人av片| 免费91在线视频| 成人www视频在线观看| 久久综合九色九九| 欧美多人爱爱视频网站| 欧美丰满少妇xxxxx| 国产97人人超碰caoprom| 日韩精品在线看| 国产99久久精品一区二区永久免费| 亚洲女人天堂网| 亚洲最新av在线网站| 亚洲一区二区久久久久久| 欧美亚洲激情视频| 亚洲va欧美va在线观看| 国产精品视频在线播放| 欧美成人精品影院| 久久成人精品一区二区三区| 日韩美女福利视频| 精品中文字幕乱| 亚洲免费伊人电影在线观看av| 中文字幕免费国产精品| 青草青草久热精品视频在线网站| 欧美劲爆第一页| 成人xxxxx| 欧美性生交xxxxx久久久| 亚州精品天堂中文字幕| 国产精品亚洲网站| 国产九九精品视频| 色综合久久悠悠| 国产999精品久久久| 国产亚洲视频中文字幕视频| 亚洲精品在线看| 国产精品久久久久av| 国产精品一二区| 亚洲最大福利视频网站| 国产午夜一区二区| 日韩电影中文字幕一区| 欧美性xxxx极品高清hd直播| 亚洲曰本av电影| 91久久久久久久| 久久久久久久国产精品视频| 精品久久久久久久久久久久| 欧美激情精品久久久| 久久在线视频在线| 国产成人拍精品视频午夜网站| 国产精品v片在线观看不卡| 亚洲人成在线播放| 欧洲美女免费图片一区| 成人国产精品久久久| 91免费看片网站| 福利一区福利二区微拍刺激| 北条麻妃一区二区三区中文字幕| 在线成人一区二区| 国产男女猛烈无遮挡91| 亚洲欧美一区二区精品久久久| 精品视频在线播放| 91亚洲永久免费精品| 欧美日韩激情小视频| 亚洲人成在线观看网站高清| 亚洲欧美日韩天堂| 亚洲国产精品久久91精品| 日韩暖暖在线视频| 米奇精品一区二区三区在线观看| 欧美亚洲国产日本| 国产精品对白刺激| 欧美日韩国产中字| 亚洲欧美日韩一区二区三区在线| 欧美精品在线观看91| 亚洲精品98久久久久久中文字幕| 国产成人精品国内自产拍免费看| 欧美性猛交99久久久久99按摩| 欧美重口另类videos人妖| 日韩欧美在线视频| 97视频国产在线| 久久影视三级福利片| 亚洲网站在线看| 国产精品久久久久久婷婷天堂| 精品视频—区二区三区免费| 久久精品欧美视频| 97不卡在线视频| 欧美极品少妇xxxxⅹ裸体艺术| 亚洲精品视频免费在线观看| 国产免费一区视频观看免费| 精品福利一区二区| 在线视频精品一| 日韩女优人人人人射在线视频| 欧美另类老肥妇| 曰本色欧美视频在线| 亚洲福利影片在线| 青草青草久热精品视频在线网站| 中文字幕一精品亚洲无线一区| 91在线观看免费高清| 欧美成人精品h版在线观看| 欧美激情a在线| 国产99久久精品一区二区| 国产精品久久av| 一区二区三区在线播放欧美| 久久97久久97精品免视看| 国产亚洲成av人片在线观看桃| 97久久精品人人澡人人爽缅北| 日韩欧美精品中文字幕| 亚洲欧美日韩中文视频| 国产精品久久久久免费a∨大胸| 日韩av免费网站| 在线播放日韩av| 欧美大奶子在线| 日韩va亚洲va欧洲va国产| 亚洲免费电影一区| 欧美日韩国产中文字幕| 亚洲精品99999| 国内精品国产三级国产在线专| 欧美电影免费观看高清| 欧美人与物videos| 川上优av一区二区线观看| 全色精品综合影院| 毛片精品免费在线观看| 精品无人区太爽高潮在线播放| 欧美电影在线观看网站| 最近2019中文字幕第三页视频| 欧美激情精品久久久久久免费印度| 亚洲第一精品夜夜躁人人躁| 欧美日韩高清在线观看| 亚洲欧美日韩在线高清直播| 韩国v欧美v日本v亚洲| 91久热免费在线视频| 亚洲精品国产品国语在线| 热久久美女精品天天吊色| 国内精品久久影院| 91国内精品久久| 欧美性感美女h网站在线观看免费| 国产aⅴ夜夜欢一区二区三区| 亚洲视频在线免费看| 国产精品com| 97福利一区二区| 亚洲黄色av网站| 国产欧美日韩高清| 国产亚洲在线播放| 91视频国产高清|