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

首頁 > 編程 > PHP > 正文

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

2020-03-22 18:00:05
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了Yii2.0表關聯查詢的方法,結合實例形式分析了Yii中關聯查詢的實現方法與相關使用技巧,需要的朋友可以參考下

 

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

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

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

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

html' target='_blank'>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 }

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

相關推薦:

Yii中表單用法實例

關于YII關聯查詢的解析

 

以上就是對于Yii2.0表關聯查詢的分析的詳細內容,PHP教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
蜜月aⅴ免费一区二区三区| 日韩亚洲在线观看| 亚洲国产成人久久综合一区| 久久精品99久久香蕉国产色戒| 亚洲视频在线视频| 一本一道久久a久久精品逆3p| 久久久国产精品免费| 欧美成人黑人xx视频免费观看| 亚洲精品一区二三区不卡| 国产精品偷伦视频免费观看国产| 亚洲自拍偷拍第一页| 欧美大全免费观看电视剧大泉洋| 国产99在线|中文| 亚洲人高潮女人毛茸茸| 九九视频这里只有精品| 中文字幕精品—区二区| 51精品国产黑色丝袜高跟鞋| 国产亚洲欧洲高清| 日本道色综合久久影院| 国产精品自拍视频| 亚洲国产精品va在线观看黑人| 久久精品在线视频| 在线看日韩av| 另类天堂视频在线观看| 91欧美精品午夜性色福利在线| 日韩av不卡电影| 亚洲一品av免费观看| 国产精品久久久久久久一区探花| 亚洲电影在线看| 黑人欧美xxxx| 97久久久久久| 精品国产欧美一区二区五十路| 日韩中文字幕在线免费观看| 日韩欧美在线视频观看| 精品亚洲aⅴ在线观看| www.日韩欧美| 国产精品久久久久久久久久久新郎| 91系列在线播放| 欧美放荡办公室videos4k| 亚洲天堂视频在线观看| 国产精品欧美日韩久久| 日韩中文字幕视频在线观看| 国产成人拍精品视频午夜网站| 日韩在线观看视频免费| 久久在线视频在线| 日韩精品999| 日本精品视频在线| 3344国产精品免费看| 亚洲成人999| 亚洲欧美另类自拍| 亚洲sss综合天堂久久| 国产精品自在线| 久久精品男人天堂| 欧美国产乱视频| 久久精品国产精品亚洲| 欧美大片在线免费观看| 亚洲天堂色网站| 日本不卡视频在线播放| 丝袜美腿亚洲一区二区| 欧美色道久久88综合亚洲精品| 欧美久久久精品| 一区国产精品视频| 久热精品视频在线观看| 国产一区二区三区三区在线观看| 精品一区精品二区| 中文字幕欧美日韩| 欧美另类69精品久久久久9999| 欧美大肥婆大肥bbbbb| 成人av.网址在线网站| 国产精品一区二区久久久久| 欧美国产日韩一区| 亚洲第一天堂无码专区| 91国产精品91| 亚洲美女自拍视频| 国产成人综合精品| 久久精品视频在线| 精品国偷自产在线视频| 国产一区二区日韩| 性色av一区二区三区| 亚洲电影免费在线观看| 亚洲一区二区三区在线免费观看| 欧美日韩在线看| 久久视频在线观看免费| 国产精品扒开腿爽爽爽视频| 久久精品国产清自在天天线| 狠狠爱在线视频一区| 亚洲3p在线观看| 亚洲tv在线观看| 欧美国产在线电影| 欧美另类在线播放| 青青在线视频一区二区三区| 欧美极品第一页| 欧美日韩国内自拍| 欧美精品一区二区三区国产精品| 国产xxx69麻豆国语对白| 日本国产精品视频| 亚洲精品第一国产综合精品| 国产一区二区美女视频| 日韩中文字幕亚洲| 日韩欧美成人精品| 欧美午夜丰满在线18影院| 欧美特黄级在线| 日韩**中文字幕毛片| 国产欧美日韩免费看aⅴ视频| 久久天天躁狠狠躁夜夜躁2014| 97超碰蝌蚪网人人做人人爽| 97精品一区二区三区| 国产精品免费一区二区三区都可以| 欧美电影在线观看网站| 97涩涩爰在线观看亚洲| 久久影视三级福利片| 欧洲亚洲在线视频| 九九热这里只有在线精品视| 高清一区二区三区日本久| 亚洲va电影大全| 亚洲男人天堂网站| 国产婷婷成人久久av免费高清| 国模私拍视频一区| 国产专区欧美专区| 精品国产乱码久久久久酒店| 国产精品视频一区二区三区四| 精品久久久久国产| 日韩中文视频免费在线观看| 亚洲国产中文字幕在线观看| 日韩国产在线播放| 最好看的2019的中文字幕视频| 亚洲国产成人久久综合| 亚洲天堂av在线免费| 欧美在线一区二区视频| 在线色欧美三级视频| 国产在线拍揄自揄视频不卡99| 亚洲美女久久久| 国产精品av电影| 欧美精品免费播放| 日韩免费av一区二区| 激情av一区二区| 黄色一区二区在线观看| 久久久久久久久亚洲| 91精品在线观看视频| 色偷偷偷综合中文字幕;dd| 最新日韩中文字幕| 国产拍精品一二三| 国产精品成人观看视频国产奇米| 国产精品久久久久久网站| 亚洲国产成人爱av在线播放| 中文字幕亚洲激情| 欧洲成人午夜免费大片| 日韩a**中文字幕| 韩国精品久久久999| 亚洲自拍偷拍一区| 一区二区三区美女xx视频| 国产一区二中文字幕在线看| 国产成人福利网站| 欧美一级淫片aaaaaaa视频| 精品国产鲁一鲁一区二区张丽| 国产精品午夜一区二区欲梦| 亚洲性69xxxbbb| 亚洲欧美国产日韩天堂区| 国产亚洲精品日韩| 国产视频观看一区| 国模极品一区二区三区| 亚洲欧美日韩国产中文| 欧美成人黑人xx视频免费观看| 欧美理论电影在线观看|